学习http请求原理

本文详细解析了HTTP的工作流程,包括DNS查找、TCP连接、请求与响应等阶段,并介绍了HTTP的五层网络协议。同时,对比了URI、URL与URN的区别,深入探讨了HTTP的方法、状态码及缓存策略,如Cache-Control的使用。最后,讲解了HTTPS的安全加密原理及HTTP2的性能提升机制。
摘要由CSDN通过智能技术生成

深入学习http

http过程
1,redirect(判断是否跳转) 2,app cache(查找缓存) 3,dns(查找地址) 4,tcp(建立链接) 5,request(发送数据) 6,response(响应数据)

5层网络协议

应用层 http ftp
传输层 tcp udp
网络层 系统级别(实现ip地址)
数据链层 实现硬件链接
物理层 建立硬件链接

三次握手

为了解决多余的数据开销的问题

##URI URL URN
URI 统一资源标识符
URL 统一资源定位符,定义资源位置
URN 永久统一资源定位符(不成熟)

报文

http 方法 HTTP1.0 GET, POST 和 HEAD方法。
HTTP1.1 新增了六种请求方法:OPTIONS、PUT、PATCH、DELETE、TRACE 和 CONNECT 方法。
http code 状态码

请求限制

可以进行预处理,就是发送数据的时候,
比如包含了方法为,put (还有其他的,头信息等),那么默认浏览器是不处理结果的,这时候需要服务器返回数据头,让浏览器进行处理

缓存(主要是设置缓存)

Cache-Control 是最重要的规则。常见的取值有private、public、no-cache、max-age,no-store,默认为private。
private: 客户端可以缓存
public: 客户端和代理服务器都可缓存(前端的同学,可以认为public和private是一样的)
max-age=xxx: 缓存的内容将在 xxx 秒后失效
no-cache: 需要使用对比缓存来验证缓存数据(后面介绍)
no-store: 所有内容都不会缓存,强制缓存,对比缓存都不会触发(对于前端开发来说,缓存越多越好,so…基本上和它说886)

cookie

Domain:域,表示当前cookie所属于哪个域或子域下面。
对于服务器返回的Set-Cookie中,如果没有指定Domain的值,那么其Domain的值是默认为当前所提交的http的请求所对应的主域名的。比如访问 http://www.example.com,返回一个cookie,没有指名domain值,那么其为值为默认的www.example.com。
Path:表示cookie的所属路径。
Expire time/Max-age:表示了cookie的有效期。expire的值,是一个时间,过了这个时间,该cookie就失效了。或者是用max-age指定当前cookie是在多长时间之后而失效。如果服务器返回的一个cookie,没有指定其expire time,那么表明此cookie有效期只是当前的session,即是session cookie,当前session会话结束后,就过期了。对应的,当关闭(浏览器中)该页面的时候,此cookie就应该被浏览器所删除了。
secure:表示该cookie只能用https传输。一般用于包含认证信息的cookie,要求传输此cookie的时候,必须用https传输。
httponly:表示此cookie必须用于http或https传输。这意味着,浏览器脚本,比如javascript中,是不允许访问操作此cookie的。

数据协商

分类
请求 Accept
返回 Content

Accept
Accept 声明想要数据的类型
Accept-Encoding 数据以哪种编码方式传输,限制服务端如何进行数据压缩。
Accept-Language 展示语言
User-Agent 浏览器相关信息,移动端、客户端、pc端的浏览器 User-Agent 不同。

Content服务端返回
Content-Type 对应 Accept,从 Accept 中选择数据类型返回
Content-Encoding 对应 Accept-Encoding,声明服务端数据压缩的方式
Content-Language 对应 Accept-Language,是否根据请求返回语言

nginx

代理可以修改头,使用下面代码
proxy_set_header Host $host;

代理缓存 ,这里没有 了解更多。不过挺重要的

proxy_cache_path /soft/cache levels=1:2 keys_zone=cache:10m max_size=10g inactive=60m use_temp_path=off;
    #proxy_cache    //存放缓存临时文件
    #levels         //按照两层目录分级
    #keys_zone      //开辟空间名,10m:开辟空间大小,1m可存放8000key
    #max_size       //控制最大大小,超过后Nginx会启用淘汰规则
    #inactive       //60分钟没有被访问缓存会被清理
    #use_temp_path  //临时文件,会影响性能,建议关闭
proxy_cache cache;
proxy_cache_valid   200 304 12h;
proxy_cache_valid   any 10m;
add_header  Nginx-Cache "$upstream_cache_status";
proxy_next_upstream error timeout invalid_header http_500 http_502 http_503 http_504;
    #proxy_cache            //开启缓存
    #proxy_cache_valid      //状态码200|304的过期为12h,其余状态码10分钟过期
    #proxy_cache_key        //缓存key
    #add_header             //增加头信息,观察客户端respoce是否命中
    #proxy_next_upstream    //出现502-504或错误,会跳过此台服务器访问下一台服务器

https 和 http2

https 主要是加密了,安全性大大提高,有很多这方面的文章非常简单

http2 变化非常大,启动他,需要先开启https 然后用 nginx ,现在没有条件,有时间去学习一下,对http 的速度会大量的提升
他主要是,多了,通道复用,可以分片传输,也可以推送数据了,这里速度提升特别明显

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

两个人的幸福online

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值