一:HTTP协议解析
1.HTTP协议即超文本传输协议,是一种详细规定了浏览器和万维网服务器之间互相通信的规则,他是万维网交换信息的基础,它允许将HTML(超文本标记语言)文档从web服务器传送到web浏览器。
2.发起一个HTTP请求
①借助浏览器可以发起一个HTTP请求,输入URL
②不借助浏览器的时候,可以使用工具:curl
3.HTTP协议详解
目前HTTP协议最新版本为1.1,HTTP协议是一种无状态协议。无状态协议指的是web浏览器与web服务器之间不需要建立持久的连接,这意味着当一个客户端向服务器发出请求,然后web服务器返回响应,连接就关闭了,在服务器端不保留连接的有关信息。也就是说HTTP请求只能由客户端发起,服务端不能主动向客户端发送数据。
HTTP遵循请求/应答模型,Web浏览器向Web服务器发送请求时,Web服务器处理请求并返回适当的应答。如下图:
HTTP请求包括三部分:1.请求行,即第一行;2.请求头(第二行至空白处);3.请求正文,空白下。
HTTP响应包括三部分:1.响应行,即第一行;2.响应头(第二行至空白处);3.响应正文,空白下。
4.HTTP请求方法
HTTP请求方法中最常见的为get和post。
①GET
GET方法主要用于获取请求页面的指定信息(以实体的格式),如果请求资源为动态脚本(非HTML),那么返回文本是web容器解析后的HTML源代码,而不是源文件。例如请求1.jsp,那么返回的不是1.jsp的源文件,而是经过解析的HTML代码。在浏览器中看到的就是经过解析渲染的页面。
②POST
POSt方法与GET方法类似,但是区别在于,GET方法没有请求内容,POST方法是有请求内容的。POST请求多用于向服务器发送大量的数据。GET也可以,但是有大小限制,并且GET请求会将发送的数据显示在浏览器端,而POST不会,所以相对来说安全一点。
③HEAD
HEAD方法除了服务器不能在响应里返回消息主体外,其他的和GET方法相同。主要用于获取报头,经常被用来测试超文本链接的有效性、可访问性和最近的改变。攻击者编写工具时,经常使用HEAD方法,因为只测试资源是否存在,而不用返回消息主题,所以速度比较快。
一个经典的HEAD请求如下:
HEAD /index.php HTTP/1.1 HOST:www.aaa.com
④PUT
PUT方法用于请求服务器把请求中的实体存储在请求资源下,如果请求资源已经在服务器中存在,那么将用此请求中的数据替换原先的数据,作为指定资源的最新修改版。如果请求指定的资源不存在,将会创建这个资源,且数据位于请求正文,请求如下:
PUT /1.txt HOST:www.aaa.com Content-length:6 123456
这段请求将会在主机根目录下创建1.txt,内容为123456,一般会将put方法关闭,因为他会在服务器中建立文件,属于危险方法之一。
⑤DELETE
DELETE方法用于请求资源服务器删除请求的指定资源。服务器一般会关闭此方法,因为在客户端可以进行删除操作,属于危险方法之一。
⑥TRACE
TRACE方法用于回显服务器收到的请求,主要用于测试和诊断。
⑦CONNECT
HTTP/1.1协议规范保留了CONNECT方法,此方法是为了用于能动态切换到隧道的代理。
⑧OPTIONS
允许客户端查看服务器的性能
5.状态码
客户端向服务器发送请求之后,服务器进行响应,HTTP响应的第一行正在,就会反应状态码。
HTTP协议中的状态码为三位数,第一位数字定义响应的类型,且只有5种:
①1XX:信息提示,表示请求已被成功接收,继续处理。范围为100~101。
②2XX:成功,服务器成功的处理了请求,范围为200~206。
③3XX:重定向,重定向状态码用于告诉浏览器客户端,他们访问的字眼已被移动,并告诉客户端新的资源地址位置。这是,浏览器将重新对资源发起请求,其范围为300~305。
④4XX:客户端错误的状态码,优势客户端会发送一些服务器无法处理的东西,比如格式错误的i请求,最常见的时,请求一个不存在的URL,其范围为400~415。
⑤5XX:有时客户端发送一条有效请求,单web服务器自身却出错了,可能时web服务器运行错误,或者网站挂掉了。5XX就是用来描述服务器内部错误的,其范围为500~505。
常见的一些状态码:
200:客户端请求成功,最常见的状态。 302:重定向。 404:请求资源不存在。 400:客户端存在语法错误,不能被服务器所理解。 401:请求未经授权。 403:服务器收到请求,但是拒绝提供服务。 500:服务器内部错误。 503:服务器当前不能处理客户端请求,一段时间后可能恢复正常 |
6.HTTP消息
具体见下一节
7.HTTP和HTTPS的区别
HTTPS协议的全称为Hypertext Transfer Protocol over Secure Socket Layer ,它是以安全为目标的HTTP通道,其实就是HTTP的“升级”版本,只是它比单纯的HTTP协议更加安全。
HTTPS的安全基础是SSL,即在HTTP下加入SSL层。HTTPS=HTTP+SSL
两者的区别主要如下:
①HTTP是超文本传输协议,信息是明文传输,HTTPS则是具有安全性的SSL加密传输协议。
②HTTP和HTTPS使用的连接方式不同,HTTP使用80端口,HTTPS使用443端口。