详解Http

详解Http,第1张

(1)HyperText Transfer Protocol 超文本传输协议

(2)解释

协议:"协"代表两个人以上,"议"代表一种规范,约束

传输:把A搬到B点,双向协议,我们访问报读的流程:

我们是请求方A,百度就是应答方B,双方约定用HTTP协议传输,brower把请求数据发送给网站,网站在把一些数据返回给浏览器,浏览器在渲染到屏幕,我们就看到图片了

超文本:超越了普通文本的文本呗! 早期的字符 =>图片,视频,压缩包等

1xx:提示信息,说明到现在为止正常,还可以进行后续的请求

2xx:成功状态码,报文收到并正确处理

3xx:重定向

4xx:客户端错误

--400:请求报文有误

--401:请求访问需要有认证信息

--403:服务器禁止访问资源

--404:Not Found,请求的资源在服务器未找到

5xx:服务端错误

(1)Host:域名,可以请求同一台主机的不同域名网站

(2)Connection:Keep-Alive

--:Http/1.1默认采用的是TCP持久连接,可以进行复用

--:为了兼容老版本,需要加上Keep-Alive

(3)Content-Length:服务器响应client时,表明本次的数据长度

(4)Content-type: text/html 返回的数据格式, 客户端也可以用Accept设置接收的类型

(5)Content-Encoding: gzip 返回类型使用什么压缩,客户端也可以用Accept-Encoding设置接收哪些压缩方法

GET:从服务器获取资源(文本,图片,视频等...)

POST:向URI指定的资源提交数据,把我们的[留言文本消息]放入请求体body,再拼接好POST请求头,通过TCP协议发送给服务器

(1)幂等性:多次执行多次操作,那么结果都是[相同]的

(2)GET是安全且幂等:它只是[可读]操作,无论执行多少次,服务器的数据都是安全的,每次的结果都是相同的

(3)POST是不安全且不幂等:新增数据会修改服务器资源,所以是不安全,多次提交会创建多个资源,所以不是幂等的

1.Http协议底层是TCP/IP,所以GET和POST的底层也是TCP/IP,也就时说Get/Post都是TCP连接

2.Get和Post做的事情是一样的,如果给Get加上Request Body,给Post带上url参数,技术上是完全行得通的

3.举个栗子

1.C/S ====>2K/64K

业界不成文规定:浏览器(大多数)都会限制url的长度在2k个字节,而服务器(大多数)最多处理64k个字节大小的url,超过的部分不处理

2.用Get请求方式,私藏数据在Request Body

(1)有的服务器会绑定卸货,读取数据,有的直接忽略

(2)虽然Get请求方式可以把数据放在Request Body,但是却不能保证一定会被服务器接收

(1)简单:报文格式 == head + body 头部信息也是key-value的形式

(2)灵活易于扩展:

--:状态码和请求头字段都可以由开发人员自定义

--:由于http在应用层(最顶层),那么下层可以随意变化

例子:HTTPS其实就是在应用层和TCP加了一个SSL/TLS的协议

(3)跨平台,应用广泛:从台式机的浏览器到手机的各种APP,都是HTTP的应用,遍地开花

(1)无状态:

描述:好处是服务器不需要额外资源记录这些客户端状态,减轻负担,但是我们登录 ==>添加到购物车 ==>下单 ==>结算这种连贯的操作需要每次都验证一次身份,那很麻烦

解决:使用cookie在请求和响应报文记录客户端的状态

[第一次访问server,server会发放"门牌卡"给client,下次请求,client只要带上这个卡,服务器就认识你了]

(2)url地址的明文传输,不安全

描述:url地址的明文传输,不安全

解决:使用Http + SSL/TLS

(1)早期HTTP/1.0的性能问题

--描述:每发起一个请求,都要新建一个TCP连接(三次握手),而且是串行执行,增加了开销

--解决:HTTP/1.1采用了长连接,减少了连接重复的新建和断开,减轻了服务器的负担

(2)管道网络通讯

--优化串行请求:Http/1.1的长连接是基于"管道"通讯,在同一个TCP连接可以发起多个请求,之前的TCP连接时A请求后等待服务器返回,再发送B请求

--产生问题:但是服务器并不是并发处理请求,而是按照排队顺序执行,也叫做[队头堵塞],相当于高速路上堵车了

(1)安全:HTTP是明文传输,存在安全风险问题,HTTPS在TCP三次握手之后还需要进行SSL/TLS的握手过程,在进行加密报文传输

(2)端口:HTTP的端口是80, HTTPS的端口是443

(3)CA证书:HTTPS协议需要向CA机构申请数字证书,来保证服务器是可信的

(1)优化

--长连接:TCP长连接改善了HTTP/1.0短连接不断创建,断开连接造成的性能开销

--pipeline:支持管道pipeline网络传输,只要第一个请求出去了,不必等它回来就可以请求第二个,减少了整体的响应时间

(2)缺点

--头部:请求头部Header未压缩发送,而且每次都需要发送相同的头部造成浪费多

--队头阻塞:server按照请求顺序来响应,若服务器慢,导致client一直请求不到数据

--没有优先级控制

(1)HTTPS安全:HTTP/2.0是基于HTTPS的,安全性提高

(2)HPACK算法-头部压缩:若你同时发送多个请求,他们的头是一样的,那么协议会帮你消除重复部分

HPACK算法:client和server共同维护一张消息表,所有字段会存入这个表并生成一个索引号,发送只需要传索引号即可

(3)二进制的数据帧:HTTP/1.1是(报文首部+空行+报文主体),HTTP/2换成(头信息帧+数据帧),好处是接收报文后无需将明文报文转成二进制,对计算机来说可以提高传输效率

(4)数据流:

--非顺序:连接中连续数据包不是按照顺序发送,可能属于不同响应,

--流编号:每个请求对应一个数据流(有独立编号),客户端为奇数编号,服务端为偶数编号,客户端可以指定数据流的优先级

(5)多路复用:

--并发处理请求:移除了HTTP/1.1的串性请求,可以并发的回应多个请求,解决了[队头阻塞]问题

--例子:在TCP连接中,server收到A(耗时长),B请求,于是server先回应A已处理部分,在回应B,继续回应A的剩余部分

(6)服务器推送 server push,Cache push

--:Http/2改善了传统的[请求-应答]工作模式,服务器可主动向client发送消息

--:当brower请求HTML时,会提前把js,css静态资源主动发给client,减低延时

问题:

(1)HTTP/1.1丢包情况:在pipeline传输中有一个请求阻塞了,那么在队列后请求会统统被阻塞住了

(2)HTTP/2丢包情况: 多路复用一个TCP连接,一旦发生丢包,所有的请求都会阻塞住

解决:

(1)HTTP/3将HTTP下层的TCP协议改成了UDP,UDP是不管顺序和有无丢包的,所以不会出现HTTP/1.1的[队头阻塞]和HTTP/2的丢包重传问题

(2)UDP是不可靠连接,但基于 UDP 的 QUIC 协议 可以实现类似 TCP 的可靠性传输。

卸货分两种: 第一种是去各个工业区的玩家工厂里面买货物,之后送到各个帮派小区里卖,卖货需要体力,相对比较赚钱。 第二种是去各个国家的二级城市老农夫那买原材料,有的要去采集(比如木头就要去自己花费体力去砍别个玩家种的树,矿石等也一样)。之后拿去各个工业区的玩家工厂卖。卖也要花费体力,相对来说这种一般都是好友让你弄,因为比较亏。建议初学者 弄第一种 ,比较简单。第二种比价麻烦,还牵扯帮派控制一个服务器一种货物的价格等等 。

料场卸货手持机扫码确认收货显示磅单保存失败,可能是由于以下原因造成的:1、磅单信息输入错误;2、磅单信息附件上传失败;3、料场服务器出现故障;4、手持机内存空间不足。应该根据具体情况具体分析,并排查原因,以便及时解决问题。


欢迎分享,转载请注明来源:夏雨云

原文地址:https://www.xiayuyun.com/zonghe/692912.html

(0)
打赏 微信扫一扫微信扫一扫 支付宝扫一扫支付宝扫一扫
上一篇 2023-08-02
下一篇2023-08-02

发表评论

登录后才能评论

评论列表(0条)

    保存