热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

Http协议知识点整合

常见的Http、Methodhttp1.0定义了三种:GET:向服务器获取资源,比如常见的查询请求POST:向服务器提交数据而发送的请求Head:和get类似,返回的响应中没

常见的Http、Method

http1.0定义了三种:



  • GET: 向服务器获取资源,比如常见的查询请求

  • POST: 向服务器提交数据而发送的请求

  • Head: 和get类似,返回的响应中没有具体的内容,用于获取报头

http1.1定义了六种:



  • PUT:一般是用于更新请求,比如更新个人信息、商品信息全量更新

  • PATCH:PUT 方法的补充,更新指定资源的部分数据

  • DELETE:用于删除指定的资源

  • OPTIONS: 获取服务器支持的HTTP请求方法,服务器性能、跨域检查等

  • CONNECT: 方法的作用就是把服务器作为跳板,让服务器代替用户去访问其它网页,之后把数据原原本本的返回给用户,网页开发基本不用这个方法,如果是http代理就会使用这个,让服务器代理用户去访问其他网页,类似中介

  • TRACE:回显服务器收到的请求,主要用于测试或诊断


常见http状态码解析

浏览器向服务器请求时,服务端响应的消息头里面有状态码,表示请求结果的状态。


分类

1XX: 收到请求,需要请求者继续执行操作,比较少用;

2XX: 请求成功,常用的 200​;

3XX: 重定向,浏览器在拿到服务器返回的这个状态码后会自动跳转到一个新的URL地址,这个地址可以从响应的Location首部中获取;
好处:网站改版、域名迁移等,多个域名指向同个主站导流
必须记住:



  • 301:永久性跳转,比如域名过期,换个域名

  • 302:临时性跳转

4XX: 客户端出错,请求包含语法错误或者无法完成请求;
必须记住:



  • 400: 请求出错,比如语法协议

  • 403: 没权限访问

  • 404: 找不到这个路径对应的接口或者文件

  • 405:不允许此方法进行提交,Method not allowed,比如接口一定要POST方式,而你是用了GET

5XX: 服务端出错,服务器在处理请求的过程中发生了错误
必须记住:



  • 500: 服务器内部报错了,完成不了这次请求

  • 503: 服务器宕机


http协议无状态解决方法 COOKIE和Session



  • COOKIE数据保存在客户端,session数据保存在服务端;

  • COOKIE不是很安全,容易泄露,不能直接明文存储信息;

  • COOKIE大小和数量存储有限制;


http协议之分布式业务无状态解决方案 JWT

JWT 是一个开放标准,它定义了一种用于简洁,自包含的用于通信双方之间以 JSON 对象的形式安全传递信息的方法。可以使用 HMAC 算法或者是 RSA 的公钥密钥对进行签名。

JWT格式组成 头部、负载、签名:header+payload+signature



  1. 头部:主要是描述签名算法

  2. 负载:主要描述是加密对象的信息,如用户的id等,也可以加些规范里面的东西,如iss签发者,exp过期时间,sub 面向的用户

  3. 签名:主要是把前面两部分进行加密,防止别人拿到token进行base解密后篡改token

简单来说: 就是通过一定规范来生成token,然后可以通过解密算法逆向解密token,这样就可以获取用户信息。生成的token,可以存储在COOKIE,localstorage和sessionStorage里面。


JWT方案优点:生产的token可以包含基本信息,比如id、用户昵称、头像等信息,避免再次查库;存储在客户端,不占用服务端的内存资源,使用加解密的方式进行校验,在分布式业务中能较好的提高性能和节省空间。

JWT方案缺点:token是经过base64编码,所以可以解码,因此token加密前的对象不应该包含敏感信息,如用户权限,密码等;如果没有服务端存储,则不能做登录失效处理,除非服务端改秘钥。

http请求产生到响应的链路

1、浏览器输入url, 解析url地址是否合法 ​   
2、浏览器检查是否有缓存, 如果有直接显示。如果没有跳到第三步 ​
3、在发送http请求前,需要域名解析(DNS解析),解析获取对应过的ip地址
4、浏览器向服务器发起tcp链接,完成tcp三次握手 ​
5、握手成功后,浏览器向服务器发送http请求 ​
6、服务器收到处理的请求,将数据返回至浏览器 ​   
7、浏览器收到http响应
8、浏览器解析响应。如果响应可以缓存,则存入缓存 ​   
9、浏览器进行页面渲染


浏览器同源策略和跨域

同源策略(Same origin policy)是一种约定,它是浏览器最核心也最基本的安全功能,如果缺少了同源策略,则浏览器的正常功能可能都会受到影响。同源策略是由Netscape提出的一个著名的安全策略。

当一个浏览器的两个tab页中分别打开百度和谷歌的页面,当浏览器的百度tab页执行一个脚本的时候会检查这个脚本是属于哪个页面的,即检查是否同源,只有和百度同源的脚本才会被执行。如果非同源,那么在请求数据时,浏览器会在控制台中报一个异常,提示拒绝访问。同源策略是浏览器的行为,是为了保护本地数据不被Javascript代码获取回来的数据污染,因此拦截的是客户端发出的请求回来的数据,即请求发送了,服务器响应了,但是无法被浏览器接收。

跨域:同源政策由 Netscape 公司引入浏览器。目前,所有浏览器都实行这个政策。 最初,它的含义是指,A网页设置的 COOKIE,B网页不能打开,除非这两个网页"同源"。所谓"同源"指的是"三个相同":协议相同 、域名相同 、端口相同 。一句话:浏览器从一个域名的网页去请求另一个域名的资源时,域名、端口、协议任一不同,都是跨域。


推荐阅读
  • 本文详细探讨了在Java TCP编程中,如何理解和测量并发连接数、请求数及并发用户数,并提供了实际应用中的测试方法和优化建议。 ... [详细]
  • 本文探讨了如何在PHP与MySQL环境中实现高效的分页查询,包括基本的分页实现、性能优化技巧以及高级的分页策略。 ... [详细]
  • 深入理解:AJAX学习指南
    本文详细探讨了AJAX的基本概念、工作原理及其在现代Web开发中的应用,旨在为初学者提供全面的学习资料。 ... [详细]
  • Bootstrap Paginator 分页插件详解与应用
    本文深入探讨了Bootstrap Paginator这款流行的JavaScript分页插件,提供了详细的使用指南和示例代码,旨在帮助开发者更好地理解和利用该工具进行高效的数据展示。 ... [详细]
  • Fiddler 安装与配置指南
    本文详细介绍了Fiddler的安装步骤及配置方法,旨在帮助用户顺利抓取用户Token。文章还涵盖了一些常见问题的解决方案,以确保安装过程顺利。 ... [详细]
  • 在尝试加载支持推送通知的iOS应用程序的Ad Hoc构建时,遇到了‘no valid aps-environment entitlement found for application’的错误提示。本文将探讨此错误的原因及多种可能的解决方案。 ... [详细]
  • 对于初学者而言,搭建一个高效稳定的 Python 开发环境是入门的关键一步。本文将详细介绍如何利用 Anaconda 和 Jupyter Notebook 来构建一个既易于管理又功能强大的开发环境。 ... [详细]
  • 本文探讨了如何通过优化 DOM 操作来提升 JavaScript 的性能,包括使用 `createElement` 函数、动画元素、理解重绘事件及处理鼠标滚动事件等关键主题。 ... [详细]
  • 本文详细介绍了如何在Oracle VM VirtualBox中实现主机与虚拟机之间的数据交换,包括安装Guest Additions增强功能,以及如何利用这些功能进行文件传输、屏幕调整等操作。 ... [详细]
  • 本文详细介绍了JQuery Mobile框架中特有的事件和方法,帮助开发者更好地理解和应用这些特性,提升移动Web开发的效率。 ... [详细]
  • Requests库的基本使用方法
    本文介绍了Python中Requests库的基础用法,包括如何安装、GET和POST请求的实现、如何处理Cookies和Headers,以及如何解析JSON响应。相比urllib库,Requests库提供了更为简洁高效的接口来处理HTTP请求。 ... [详细]
  • 调试利器SSH隧道
    在开发微信公众号或小程序的时候,由于微信平台规则的限制,部分接口需要通过线上域名才能正常访问。但我们一般都会在本地开发,因为这能快速的看到 ... [详细]
  • 解决PHP项目在服务器无法抓取远程网页内容的问题
    本文探讨了在使用PHP进行后端开发时,遇到的一个常见问题:即在本地环境中能够正常通过CURL获取远程网页内容,但在服务器上却无法实现。我们将分析可能的原因并提供解决方案。 ... [详细]
  • CentOS下ProFTPD的安装与配置指南
    本文详细介绍在CentOS操作系统上安装和配置ProFTPD服务的方法,包括基本配置、安全设置及高级功能的启用。 ... [详细]
  • Web动态服务器Python基本实现
    Web动态服务器Python基本实现 ... [详细]
author-avatar
tuir
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有