HTTP特点/URL/报文

HTTP特点/URL/报文

HTTP的特点

支持客户/服务器模式

在这里插入图片描述
客户/服务器模式工作的方式是由客户端向服务器发出请求,服务器响应请求,并进行相应服务

简单快速
客户向服务器请求服务时,只需要传送请求方法和路径。
请求方法常用的有GET、HEAD、POST。每种方法规定了客户与服务器联系的类型不同
由于HTTP协议简单,使得HTTP服务器的程序规模小,因而通讯速度很快。

灵活

HTTP允许传输任意类型的对象
正在传输的类型有Content-Type(Content-Type是HTTP包中用来表示内容类型的标识)加以标记

无连接

无连接的含义是限制每次连接只处理一个请求(请求的时候链接,请求完就释放掉)
服务器处理完客户的请求,并收到客户的应答后,即断开连接(keep alive功能能够提升效率)
采用这种方式可以节省传输时间

无状态

HTTP是无状态协议
无状态是指协议对于事物处理没有记忆能力。(他传数据,但他不记)缺少状态意味着如果后续处理需要前面的信息,则它必须重传,这样可能导致每次连接传送的数据量增大。
另一方面,在服务器不需要先前信息时它的应答就较快。

有一个另外的方式能够辅助他的记忆(cookie和session)

URI和URL

在这里插入图片描述
◆URI:一个紧凑的字符串用来标示抽象或物理资源
A URI可以进一步被分为定位符、名字或两者都是

(URL) 是URI的子集,除了确定一个资源,还提供一种定位该资源的主要访问机制(如其网络“位置”)

简单来说:
URI可以分为URL,URN或同时具备locators和names特性的一个东西
URN作用就好像一个人的名字, URL就像一个人的地址
◆换句话说: URN确定了东西的身份,URL提供了找到它的方式

URL是URI的一种,但不是所有URI都是URL
URI和URL最大的差别是“访问机制”(比如是通过http还是ftp)
URN是唯一标识的一部分,是身份信息
在这里插入图片描述

HTTP报文

HTTP报文结构分析–请求报文
在这里插入图片描述
报文第一行:报文协议及版本 状态码及状态描述
HTTP报文头大体可以分为四类,分别是:
通用报文头、请求报文头、响应报文头和实体报文头
在HTTP/1.1里一共规范了47种报文头字段
四类报文头

在这里插入图片描述在这里插入图片描述

在这里插入图片描述在这里插入图片描述
常用报文头

1.ACCEPT
作用:浏览器可以接受的媒体类型
Accept:text/html 代表浏览器可以接受服务器回发的类型为text/html也就是我们常说的html文档,如果服务器无法返回text/html类型的数据,服务器应该返回一个406错误(Non Acceptable)
Accept: */*代表浏览器可以处理所有类型

如果想要给显示的媒体类型增加优先级,则使用q=来额外表示权重值;权重时q的范围时0-1(可精确到小数点后3位),且1为最大值。不指定权重q值时,默认权重为q=1.0。当服务器提供多种内容时,将会首先返回权重值最高的媒体类型。

2.Accepte-Encoding
作用:浏览器申明自己接收的编码方法,通常指定压缩方法,是否支持压缩,支持什么压缩方法(gzip,deflate)

3.Accepte-Language
作用:浏览器申明自己接收的语言
Accepte-Language: zh-cn,zh;q=0.7,en-us,en;q=0.3
客户端在服务器有中文版资源的情况下,会请求其返回中文版对应的响应,没有中文版时,则请求返回英文版响应

4.Connection
Connection: keep-alive 当一个网页打开完成后,客户端和服务器之间用于传输HTTP数据的TCP连接不会关闭,如果客户端再次访问这个服务器上的网页,会继续使用这一条已经建立的连接

Connection: close 代表一个Request完成后,客户端和服务器之间用于传输HTTP数据的TCP连接会关闭,当客户端再次发送Request,需要重新建立TCP连接。

5.Host
作用:请求报头域主要用于指定被请求资源的Internet主机和端口号,它通常从HTTP URL中提取出来的
我们在浏览器中输入: http://www.fljf.com:8080
浏览器发送的请求消息中,就会包含Host请求报头域,如下:Host: www.fljf.com:8080

6.Referer
当浏览器向web服务器发送请求的时候,一般会带上Referer,告诉服务器我是从哪个页面链接过来的,服务器藉此可以获得一些信息用于处理

7.User-Agent
作用:告诉HTTP服务器,客户端使用的操作系统和浏览器的名称和版本(以防止和我们相差太多)
很多情况下我们会通过User-Agent来判断浏览器类型,从而进行不同的兼容设计

8.Content-type
作用:说明了报文体内对象的媒体类型
text/html:HTML格式
text/plain:纯文本格式
text/xml:XML格式
image/gif: gif图片格式
image/jpeg: jpg图片格式
image/png: png图片格式
application/xhtml+xml: XHTML格式
application/xml : XML数据格式
application/atom + xml : Atom XML 聚合格式
application/json: JSON数据格式
application/pdf: pdf格式
application/msword: Word文档格式
application/octet-stream: 二进制流数据(如常见的文件下载)
application/x-www-form-urlencoded: 表单提交

HTTP报文结构分析–响应报文
在这里插入图片描述
响应头 响应体
报文第一行:报文协议及版本 状态码及状态描述
响应体

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
对于第一个问题,客户端与服务器之间会传输一些握手数据,包括SYN,SYN-ACK和ACK等数据包,用于建立TCP连接。这些数据报文的作用是建立可靠的传输通道,确保后续的HTTP请求和响应报文能够准确无误地传输。 对于第二个问题,HTTP请求报文的“请求行”内容如下: - 请求方法字段数值为GET,代表客户端请求服务器返回某个资源; - 请求的URL字段数值为“/”,代表请求服务器的根目录; - HTTP协议版本字段数值为HTTP/1.1,代表使用的HTTP协议版本为1.1。 HTTP请求报文的“请求报头”内容中,各字段的数值及其含义分别如下: - Host字段:www.example.com,代表服务器的主机名; - Referer字段http://www.example.com/index.html,代表请求来源页面的URL; - UserAgent字段:Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/58.0.3029.110 Safari/537.36 Edge/16.16299,代表客户端浏览器的类型和版本信息; - Connection字段:keep-alive,代表客户端请求保持连接状态; - Accept字段:text/html,application/xhtml+xml,application/xml;q=0.9,image/webp,image/apng,*/*;q=0.8,代表客户端可接受的MIME类型; - Accept Encoding字段:gzip, deflate,代表客户端可接受的压缩算法; - Accept-Language字段:zh-CN,zh;q=0.9,代表客户端可接受的自然语言类型。 HTTP请求报文的“请求包体”中没有关键内容Username与Password。 根据上述信息,HTTP请求报文传输过程中存在以下隐患或问题: - HTTP请求报文中的URL和明文的请求报文头信息可能会被中间节点窃取,造成安全隐患; - HTTP请求报文中的请求方法和请求头信息可能会被篡改,造成恶意攻击。 对于第六个问题,".NET CLR 3.5.30729"代表客户端浏览器所使用的.NET Framework版本号。 对于第七个问题,HTTP的优点包括: - 简单易用,易于开发和实现; - 支持客户端和服务器之间的交互,实现灵活性和可扩展性; - 可以通过传输文件、图片等多种形式的数据。 HTTP的缺点包括: - 不安全,容易被窃取或篡改; - 无法处理大量的并发请求,容易造成服务器压力过大; - 无法处理多媒体数据的流式传输。 为了改进HTTP,可以采用以下方法: - 使用HTTPS协议进行数据传输,保证传输过程中的安全性; - 使用CDN等技术进行负载均衡,缓解服务器压力; - 使用新的协议或技术,如SPDY、HTTP/2等,提高传输效率和数据传输的安全性。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值