热门标签 | 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网页不能打开,除非这两个网页"同源"。所谓"同源"指的是"三个相同":协议相同 、域名相同 、端口相同 。一句话:浏览器从一个域名的网页去请求另一个域名的资源时,域名、端口、协议任一不同,都是跨域。


推荐阅读
  • LVS实现负载均衡的原理LVS负载均衡负载均衡集群是LoadBalance集群。是一种将网络上的访问流量分布于各个节点,以降低服务器压力,更好的向客户端 ... [详细]
  • 本文介绍了Java工具类库Hutool,该工具包封装了对文件、流、加密解密、转码、正则、线程、XML等JDK方法的封装,并提供了各种Util工具类。同时,还介绍了Hutool的组件,包括动态代理、布隆过滤、缓存、定时任务等功能。该工具包可以简化Java代码,提高开发效率。 ... [详细]
  • 开发笔记:计网局域网:NAT 是如何工作的?
    篇首语:本文由编程笔记#小编为大家整理,主要介绍了计网-局域网:NAT是如何工作的?相关的知识,希望对你有一定的参考价值。 ... [详细]
  • 本文介绍了南邮ctf-web的writeup,包括签到题和md5 collision。在CTF比赛和渗透测试中,可以通过查看源代码、代码注释、页面隐藏元素、超链接和HTTP响应头部来寻找flag或提示信息。利用PHP弱类型,可以发现md5('QNKCDZO')='0e830400451993494058024219903391'和md5('240610708')='0e462097431906509019562988736854'。 ... [详细]
  • 单页面应用 VS 多页面应用的区别和适用场景
    本文主要介绍了单页面应用(SPA)和多页面应用(MPA)的区别和适用场景。单页面应用只有一个主页面,所有内容都包含在主页面中,页面切换快但需要做相关的调优;多页面应用有多个独立的页面,每个页面都要加载相关资源,页面切换慢但适用于对SEO要求较高的应用。文章还提到了两者在资源加载、过渡动画、路由模式和数据传递方面的差异。 ... [详细]
  • 2021最新总结网易/腾讯/CVTE/字节面经分享(附答案解析)
    本文分享作者在2021年面试网易、腾讯、CVTE和字节等大型互联网企业的经历和问题,包括稳定性设计、数据库优化、分布式锁的设计等内容。同时提供了大厂最新面试真题笔记,并附带答案解析。 ... [详细]
  • 本文分享了一位Android开发者多年来对于Android开发所需掌握的技能的笔记,包括架构师基础、高级UI开源框架、Android Framework开发、性能优化、音视频精编源码解析、Flutter学习进阶、微信小程序开发以及百大框架源码解读等方面的知识。文章强调了技术栈和布局的重要性,鼓励开发者做好学习规划和技术布局,以提升自己的竞争力和市场价值。 ... [详细]
  • 篇首语:本文由编程笔记#小编为大家整理,主要介绍了VoLTE端到端业务详解|VoLTE用户注册流程相关的知识,希望对你有一定的参考价值。书籍来源:艾怀丽 ... [详细]
  • IP、ARP、TCP、UDP、ICMP、DNS、路由协议、DHCP协议的缺陷,容易受到的攻击,以及防御措施1、IP协议1.1、介绍: ... [详细]
  • 加密、解密、揭秘
    谈PHP中信息加密技术同样是一道面试答错的问题,面试官问我非对称加密算法中有哪些经典的算法?当时我愣了一下,因为我把非对称加密与单项散列加 ... [详细]
  • 技术分享:如何在没有公钥的情况下实现JWT密钥滥用
      ... [详细]
  • 微服务应用性能分析实战15 数据磐石:APM 收集端的存储模型
    分布式监控的重要设计就是数据存储模型,而SkyWalking的分布式追踪数据模型就是一个经典代表,这也是它会在APM领域脱颖而出的原因。所以今天我就以 ... [详细]
  • 现在很多App在与服务器接口的请求和响应过程中,为了安全都会涉及到加密和解密的问题,如果不加的话就会是明文的,即使加了GZIP也可以被直接解压成明文。如果同时有Android和IO ... [详细]
  • 一、前言个人认为,PHP是世界上为数不多,最人性化的语言。虽然是二次开发、弱类型语言,由CC编写的PHP引擎去解析。但是,其 ... [详细]
  • 集成电路企业在进行跨隔离网数据交换时面临着安全性问题,传统的数据交换方式存在安全性堪忧、效率低下等问题。本文以《Ftrans跨网文件安全交换系统》为例,介绍了如何通过丰富的审批流程来满足企业的合规要求,保障数据交换的安全性。 ... [详细]
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社区 版权所有