web安全入门-http请求报文

Posted 最爱大苹果

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了web安全入门-http请求报文相关的知识,希望对你有一定的参考价值。

web的时代,我们会经常跟http协议打交道。


http协议:


超文本传输协议(Hyper Text Transfer Protocol,HTTP)是一个简单的请求-响应协议,它通常运行在TCP之上。它指定了客户端可能发送给服务器什么样的消息以及得到什么样的响应。


web安全入门-http请求报文_web安全入门


http请求报文类型:


http的请求报文有两类

1、get方式,获取web服务器数据

2、post方式,向web服务器提交数据

post方式比get方式安全


请求报文格式


---- 请求行 ----
GET / HTTP/1.1 # GET请求方式 请求资源路径 HTTP协议版本
---- 请求头 -----
Host: www.itcast.cn # 服务器的主机地址和端口号,默认是80
Connection: keep-alive # 和服务端保持长连接
Upgrade-Insecure-Requests: 1 # 让浏览器升级不安全请求,使用https请求
User-Agent: Mozilla/5.0 (Macintosh; Intel Mac OS X 10_12_4) AppleWebKit/537.36 (Khtml, like Gecko) Chrome/69.0.3497.100 Safari/537.36 # 用户代理,也就是客户端的名称
Accept:text/html,application/xhtml+xml,application/xml;q=0.9,image/webp,image/apng,*/*;q=0.8 # 可接受的数据类型
Accept-Encoding: gzip, deflate # 可接受的压缩格式
Accept-Language: zh-CN,zh;q=0.9 #可接受的语言
Cookie: pgv_pvi=1246921728; # 登录用户的身份标识

---- 空行 ----


每项数据之间使用:\\r\\n结束。


---- 请求行 ----
POST /xmweb?host=mail.itcast.cn&_t=1542884567319 HTTP/1.1 # POST请求方式 请求资源路径 HTTP协议版本
---- 请求头 ----
Host: mail.itcast.cn # 服务器的主机地址和端口号,默认是80
Connection: keep-alive # 和服务端保持长连接
Content-Type: application/x-www-form-urlencoded # 告诉服务端请求的数据类型
User-Agent: Mozilla/5.0 (Macintosh; Intel Mac OS X 10_12_4) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/69.0.3497.100 Safari/537.36 # 客户端的名称
---- 空行 ----
---- 请求体 ----
username=hello&pass=hello # 请求参数


报文组成


一个HTTP请求报文可以由请求行、请求头、空行和请求体4个部分组成。


web安全入门-http请求报文_web安全入门_02


web安全入门-http请求报文_web安全入门_03


字段解析,可参考文章


上图为http请求报文解析。



以上是关于web安全入门-http请求报文的主要内容,如果未能解决你的问题,请参考以下文章

#WEB安全基础 : HTTP协议 | 0x10 请求和响应报文重点结构及常见头部

Http请求和Https请求的区别

Ajax入门与应用

http https协议

Python爬虫入门之二HTTP/HTTPS请求与响应

Python零基础入门爬虫原理与数据抓取--HTTP的请求与响应