工具:HttpWatch Prov7.2.13破解版(带正版key)

HTTP协议概述
 
思考2个要点:
第一:浏览器和服务器是通过什么连接的
第二:这种连接方式是怎么实现的
 
通过Internet去发送到服务器中,而internet内部可以通过三种形式来实现发送消息
第一:HTTP协议,最常用的
第二:FTP协议。
第三:TCP/IP协议,它也是最底层的协议,想要实现这种协议必须要实现Socket编程,然后实现socket编程又分为客户端和服务端,服务器端的任务就是监听某一个端口,接收客户端的链接,客户端一旦链接到服务器端,就会以流的方式发送数据,但是这种做法是用来上传一些大的文件、视频、进行断点续传。
 
HTTP协议实例剖析
客户端(浏览器)连接服务器实现的内部原理,以输入“https://www.baidu.com/”为例进行说明
1. 浏览器输入“https://www.baidu.com/”,浏览器得到这个网址后(不要忘记浏览器也是一种软件,也可以说我们把数据传给了这个软件),内部就会将这个域名发送到DNS上,进行域名解析,得到它的IP之后就会连接到百度的这个服务器上面,百度的服务器假设是220.181.112.244并链接到80端口,从浏览器到服务器端口它使用了最底层的TCP/IP协议
2.实现TCP/IP协议用Socket来完成,使用了Socket套接字,客户端和服务端都开了一个Socket
3.服务端的80端口监听客户端的链接,这样客户端到服务器端就连接上了。
 
要发送数据到服务器端,通过HTTP协议必须严格按照它的格式来执行,那么HTTP协议到底发送了什么格式的数据呢?可以通过工具HttpWatch来监听客户端所发送的内容
 
HTTP协议发送的具体内容:
 
具体的请求头:

Headers Sent      Value
(Request-Line)    GET / HTTP/1.1
Accept    application/x-ms-application, image/jpeg, application/xaml+xml, image/gif, image/pjpeg, application/x-ms-xbap, application/vnd.ms-excel, application/vnd.ms-powerpoint, application/msword, */*
Accept-Encoding    gzip, deflate
Accept-Language    zh-CN
Connection    Keep-Alive
Cookie    BD_UPN=1123314351; BD_LAST_QID=12375416872890278785; BAIDUID=7D17821C4744D5AE56F549CC1DE4EF0C:FG=1; BIDUPSID=7D17821C4744D5AE56F549CC1DE4EF0C; PSTM=1524032327
Host    www.baidu.com
User-Agent    Mozilla/4.0 (compatible; MSIE 8.0; Windows NT 6.1; WOW64; Trident/4.0; SLCC2; .NET CLR 2.0.50727; .NET CLR 3.5.30729; .NET CLR 3.0.30729; .NET4.0C; .NET4.0E; InfoPath.3; Zoom 3.6.0)
 
说明:
1. Request-Line:  GET / HTTP/1.1 代表以get方式请求1.1版本的HTTP协议  (请求行使用了相对URL,此处示例没有显示)
2. Accept : 代表浏览器可以接受的数据类型
3. Accept-Encoding:gzip, deflate 代表浏览器可以接收压缩过后的数据。当服务器给客户端传输数据的时候为了减少流量可以进行压缩,压缩之后的数据传给浏览器,浏览器可以进行自动解压缩。
4. Accept-Language:zh-CN 代表客户端浏览器的语言。
5. Connection:Keep-Alive 代表维护长连接 (告诉服务器发送完请求的文档后是否可释放连接,即浏览器希望服务器在传送完所请求的对象后即关闭TCP连接)
6. Cookie:Cookie值
7. Host:www.baidu.com 代表请求请求的主机名 (域名)
8. User-Agent:表明用户代理
 
服务器收到这些内容,并按照这些请求的路径找到对应的网页,进一步找到网页的内容,返回给客户端。
服务器返回给客户端的内容有三种形式:
第一:以HTML代码的形式返回
第二:以XML字符串的形式返回
第三:以JSON对象形式返回。在网络流量上考虑JSON比XML要好一些。
如果在通信的过程中需要文件的上传、下载,就会以IO流的形式传输。
 
HttpWatch 监听的Overview:
Display URL    Normal browser lookup of URL https://www.baidu.com/    Completed
Started At    2018-Nov-21 09:31:17.569 (local time)    Completed
Connecting    Connecting to IP address '220.181.112.244'    Completed
Connected    Connected to IP address '220.181.112.244' from 192.168.39.187:50471    Completed
HTTP Request    Unconditional request sent for https://www.baidu.com/    Completed
HTTP Response    Headers and content returned    Completed
 
HTTP的报文结构:
HTTP有两类报文:
a. 请求报文:从客户端向服务器端发送请求报文。
b. 响应报文:从服务器到客户端的回答。

 
每个请求报文发出后,都能收到一个响应报文。响应报文的第一行就是状态行。
状态行包含三项内容,即HTTP的版本,状态码,以及解释状态码的简单短语。
状态码(status-code) 都是三位数字的,分为5大类,5大类的状态码都是以不同的数字开头的:
1xx 表示通知信息,如请求收到了或正在进行处理
2xx 表示成功,即接受或知道了。
3xx 表示重定向,如要完成请求还必须采取进一步的行动。
4xx 表示客户端的差错,如请求中有错误的语法或不能完成。
5xx 表示服务端的差错,如服务器失效无法完成请求。
 

 
Cookie的意义:
 

内容参考:
1. Android 4.0 网络编程详解 王家林
2. 计算机网络(第7版)谢希仁

HTTPWatch工具使用参考:https://www.cnblogs.com/zhuhongbao/p/3230046.html

HTTP协议剖析 (附HttpWatch工具监控网络请求)的更多相关文章

  1. Charles抓包工具过滤网络请求

    Charles是一个HTTP代理服务器,HTTP监视器,反转代理服务器,当浏览器连接Charles的代理访问互联网时,Charles可以监控浏览器发送和接收的所有数据.它允许一个开发者查看所有连接互联 ...

  2. Chrome开发者工具关于网络请求的一个隐藏技能

    这个隐藏技能的背景是,最近出于学习目的,我写了一个百度贴吧的网络爬虫,专门爬取一些指定主题的贴吧帖子. 抓取帖子用的JavaScript函数如下: function getPostByAJAX(req ...

  3. 通过nginx + lua来统计nginx上的监控网络请求和性能

    介绍 以前我们为nginx做统计,都是通过对日志的分析来完成.比较麻烦,现在基于ngx_lua插件,开发了实时统计站点状态的脚本,解放生产力. 项目主页: https://github.com/sky ...

  4. iOS - ASIHTTPRequest 网络请求

    前言 使用 iOS SDK 中的 HTTP 网络请求 API,相当的复杂,调用很繁琐,ASIHTTPRequest 就是一个对 CFNetwork API 进行了封装,并且使用起来非常简单的一套 AP ...

  5. Android 网络请求详解

    我们知道大多数的 Android 应用程序都是通过和服务器进行交互来获取数据的.如果使用 HTTP 协议来发送和接收网络数据,就免不了使用 HttpURLConnection 和 HttpClient ...

  6. LXNetwork – 基于AF3.0封装的iOS网络请求库

    本框架实现思路与YTKNetwork和RTNetworking类似,相当于一个简单版,把每一个网络请求封装成对象.使用LXNetwork,你的每一个请求都需要继承LXBaseRequest类,通过覆盖 ...

  7. 网络协议图形化分析工具EtherApe

    网络协议图形化分析工具EtherApe   在对网络数据分析的时候,渗透测试人员往往只关心数据流向以及协议类型,而不关心具体数据包的内容.因为这样可以快速找到网络的关键节点或者重要的协议类型. Kal ...

  8. 运用Ntop监控网络流量(视频Demo)

    运用Ntop监控网络流量 ____网络流量反映了网络的运行状态,是判别网络运行是否正常的关键数据,在实际的网络中,如果对网络流量控制得不好或发生网络拥塞,将会导致网络吞吐量下降.网络性能降低.通过流量 ...

  9. Httpwatch 工具介绍

    一 概述: HttpWatch强大的网页数据分析工具.集成在Internet Explorer工具栏.包括网页摘要.Cookies管理.缓存管理.消息头发送/接受.字符查询.POST 数据和目录管理功 ...

随机推荐

  1. Junit结合Spring对Dao层进行单元测试

    关于单元测试,上一次就简单的概念和Mock基础做了,参考:http://60.174.249.204:8888/in/modules/article/view.article.php/74 实际开发过 ...

  2. Fedora ssh服务,防火墙服务设置

    Fedora26 ssh设置 ssh:connection to host 127,0.0.1 port22: Connection refused 首先安装openssh-server     yu ...

  3. Android图片编码机制深度解析(Bitmap,Skia,libJpeg)

    问题 工作中遇到了Android中有关图片压缩保存的问题,发现这个问题还挺深,而且网上资料比较有限,因此自己深入研究了一下,算是把这个问题自顶至下全部搞懂了,在此记录. 相关的几个问题如下: 1.An ...

  4. scp 链接文件的问题 + tar

    将本地的文件上传到服务器上,希望保持相对链接关系.(链接文件和被链接文件都在同一的目录下) 使用scp进行传输时,链接关系不会保存,所以需要解决下.(当然可以使用rsync或tar解决,但是rsync ...

  5. 内存管理 初始化(七)kmem_cache_init_late 初始化slab分配器(下)

    我们知道kmem_cache中对于每CPU都有一个array_cache,已作为每CPU申请内存的缓存.  此函数的目的在于:每个kmem_cache都有一个kmem_list3实例,该实例的shar ...

  6. 想高效学会Hadoop,你要按照这个路线

    学习hadoop,首先我们要知道hadoop是什么? 说到底Hadoop只是一项分布式系统的工具,我们在学习的时候要理解分布式系统设计中的原则以及方法,只有这样才能以不变应万变.再一个就是一定要动手, ...

  7. Node.js之exports与module.exports

    每一个node.js执行文件,都自动创建一个module对象,同时,module对象会创建一个叫exports的属性,初始化的值是 {} module.exports = {}; Node.js为了方 ...

  8. 针对降质模型中的模糊SR

    (PDF) Deep Plug-and-Play Super-Resolution for Arbitrary Blur Kernels https://www.researchgate.net/pu ...

  9. springmvc+jsp 拦截器下如何设置欢迎页面

    0.需求 如何让用户在浏览器地址栏键入[http://XXX.XXX.XX.XX:端口号/应用名/]以后自动跳转到系统的登录界面 1.web.xml 1.1 注意welcome-file-list的配 ...

  10. opengl库区分:glut、freeglut、glfw、glew、gl3w、glad

    //oepngl库 opengl原生库 gl* 随opengl一起发布 opengl实用库 glu* 随opengl一起发布 opengl实用工具库glut glut* 需要下载配置安装(太老了!) ...