点击次数:328      更新时间:2017-04-21 10:21:00       作者:本站整理      来源:www.lan6.net        QQ交流群:626957820


 

HTTP

HTTP是一个基于TCP/IP通信协议来传递数据(超文本传输协议)

好久木来更新文章了~我又回归了,此刻鼓掌。。。。。。

今天就来分享下http协议的小知识,在接口测试中我们最常接触的HTTP协议,那么今天就来畅谈下HTTP的小世界~O(∩_∩)O~

一、工作原理

工作原理

工作原理-简易版
浏览器(ps:一切基于http协议的发起的http请求的工具)向web服务器发出请求,Web服务器根据接收到的请求后,向客户端发送响应信息。

web服务器:
默认端口号:80

  • Apache服务器
  • Nginx服务器
  • IIS服务器

HTTP三点注意事项:

  • HTTP是无连接:无连接的含义是限制每次连接只处理一个请求。服务器处理完客户的请求,并收到客户的应答后,即断开连接。采用这种方式可以节省传输时间。
  • HTTP是媒体独立的:这意味着,只要客户端和服务器知道如何处理的数据内容,任何类型的数据都可以通过HTTP发送。客户端以及服务器指定使用适合的MIME-type内容类型。
  • HTTP是无状态:HTTP协议是无状态协议。无状态是指协议对于事务处理没有记忆能力。缺少状态意味着如果后续处理需要前面的信息,则它必须重传,这样可能导致每次连接传送的数据量增大。

二、HTTP报文结构

(一)请求报文

请求报文

  • 请求行
    请求方法 、 请求URL 、 协议版本
    常见的请求方法:
    HTTP1.0定义了三种请求方法: GET, POST 和 HEAD方法。
    HTTP1.1新增了五种请求方法:OPTIONS, PUT, DELETE, TRACE 和 CONNECT 方法。
  • 请求头部
    常见的头部key/value:
    Host: 请求的主机名
    User-Agent:生成请求的浏览器类型
    Accept:客户端可识别的响应内容类型列表
    Accept-Language: 客户端可接受的自然语言
    Accept-Encoding: 客户端可接受的编码压缩格式
    Accept-Charset: 可接受的字符集
    Cookie: 存储在客户端的扩展字段
    connection:连接方式(close或keeplive)
    对于请求端来讲:
    close是告诉服务端,断开连接,不用等待后续的求请了。keeplive则是告诉服务端,在完成本次请求的响应后,保持连接,等待本次连接后的后续请求。
  • 空行
    通过一个空行,告诉服务器请求头部到此为止
  • 请求数据
    若方法字段是GET,则此项为空,没有数据
    若方法字段是POST,则通常来说此处放置的就是要提交的数据
    (fiddler中可以查看textview)

(二)响应报文

响应报文

  • 状态行
    HTTP协议版本、状态码、状态码描述三部分构成
    常见的HTTP状态码:
    200 - 请求成功
    301 - 资源(网页等)被永久转移到其它URL
    404 - 请求的资源(网页等)不存在
    500 - 内部服务器错误
    状态码
    常见状态码说明:
    200 OK: 表示客户端请求成功
    400 Bad Request: 表示客户端请求有语法错误,不能被服务器端解析
    401 Unauthonzed: 表示请求未经授权,该状态码必须与WWW-Authenticate报文头一起使用
    404 Not Found:请求的资源不存在,例如输入了错误的url
    500 Internal Server Error: 表示服务器发生了不可预期的错误,导致无法完成客户端的请求
    503 Service Unavailable:表示服务器当前不能处理客户端的请求,在一段时间后服务器可能恢复正常
  • 响应头部
    常见的响应头字段:
    Location:     这个头配合302状态码使用,用于告诉客户找谁。
    Server:      服务器通过这个头告诉浏览器服务器的类型。
    Content-Encoding: 服务器通过这个头告诉浏览器数据的压缩格式。
    Content-Length:  服务器通过这个头告诉浏览器回送数据的长度
    Content-Type:   服务器通过这个头告诉浏览器回送数据的类型
    Last-Modified:   告诉浏览器当前资源的最后缓存时间
    Refresh:     告诉浏览器隔多久刷新一次
    Content-Disposition:告诉浏览器以下载方式打开数据
    Transfer-Encoding: 告诉浏览器数据的传送格式
    ETag:       缓存相关的头
  • 空行
    通过一个空行,告诉请求端响应内容到此为止
  • 响应内容
    服务端返回给浏览器的文本信息

三、案例分析

此处以伟大的百度为案例吧~~~
此处BZ使用的是chrome的检查工具,Firefox的检查工具和第三方抓包工具都是可以的哦~
百度请求与响应

关于http协议今天就小小介绍到这里咯,网络上有许多的学习资料观看↖(^ω^)↗~
资料链接: