一个完整的http请求分析
Request URL:http://localhost:8080/test.jhtml
Request Method:POST
Status Code:200 OK
Remote Address:[::1]:8080
Referrer Policy:no-referrer-when-downgrade
//用于过滤referrer,判断是否传递refrerer报头内容
//默认值no-referrer-when-downgrade表示当从http-->https 时,允许传递referer报头内容;当从https--->http时,不允许传递referer报头内容
Response Headers view source
Access-Control-Allow-Credentials:true
//Access-Control-Allow-Credentials 属于响应方的响应报头,表示响应方是否允许将请求回来的response暴露在页面上,true表示允许,其他值表示不允许
//响应报头 服务端可以使用这种方式来设置 response.setHeader("Access-Control-Allow-Credentials", "true")
Access-Control-Allow-Headers:Origin, X-Requested-With, Content-Type, Accept
//响应报头 Access-Control-Allow-Headers 指明了实际请求中允许request header 携带的字段
Access-Control-Allow-Methods:POST, GET, OPTIONS, DELETE
//响应报头 指定访问资源允许的请求方法
Access-Control-Allow-Origin:http://localhost:8080
//响应报头 指定响应资源允许被哪个域引用,多个域之间用,隔开;*表示此资源允许被所有域引用
Access-Control-Max-Age:3600
//响应报头 表示Access-Control-Allow-Headers和Access-Control-Allow-Methods 返回的结果可以被缓存多久,单位是秒
Content-Type:application/json;charset=UTF-8
//实体报头 Content-Type属于实体报头,表示发送端(客户端|服务端)发送的实体数据类型
//application/json;charset=UTF-8 服务端返回给客户端的数据类型是json格式,编码格式是utf-8
Location: /test/testRequest.jhtml
//响应报头 指定的是一个重定向请求的目的地址(或者新创建的文件的URL)
//一般伴随重定向请求出现,状态码一般以3开头或者是201
Date:Tue, 27 Feb 2018 05:51:48 GMT
//通用报头 格林尼治标准时间,表示报文是什么时间创建的
Server:Apache-Coyote/1.1
//响应报头 说明原始服务器的软件信息,可以包含多个产品标识和注释,产品标识一般按照重要性排序。
Set-Cookie:key=""; Expires=Thu, 01-Jan-1970 00:00:10 GMT; Path=/
Set-Cookie:key=value; Path=/
Set-Cookie:JSESSIONID=7EE63E4C782506A59347EE9CA28C7798; Path=/; HttpOnly
//响应报头 用于服务端向客户端发送cookie信息
//HTTP-only类型的Cookie不能使用Javascript通过Document.cookie属性或者$.cookie()方法来访问,从而能够在一定程度上阻止跨域脚本攻击(XSS)。
//当你不需要在JavaScript代码中访问你的Cookie时,可以将该Cookie设置成HttpOnly类型
Transfer-Encoding:chunked
//chunked指HTTP/1.1支持的一种数据传输方式,叫做分块编码传输技术
//对于持续链接来说,当响应实体的内容长度不能确定时,可以使用分块编码的传输方式来界定实体的边界
//使用chunked分块编码传输技术,响应实体将被分成很多块,每一块的格式: 十六进制的长度值/r/n数据/r/n , 最后结尾的一块是0/r/n/r/n
Request Headers view source
Accept:application/json, text/javascript, */*; q=0.01
//Accept 表示发送端(客户端)希望接受的响应数据类型
//application/json 表示此请求优先接受的响应数据类型是json类型,其次是javascript类型,然后才是所有类型
//请求方的http报头类型:通用报头||请求报头||实体报头
//响应方的http报头类型:通用报头||响应报头||实体报头
//Accept属于请求报头,表示发送端(客户端)希望接受的响应数据类型
//Content-Type属于实体报头,表示发送端(客户端|服务端)发送的实体数据类型
Accept-Encoding:gzip, deflate, br
//Accept-Encoding 表示浏览器发送给服务端,告诉服务端它可以接受的编码类型
//默认是identity Accept-Encoding : identity
//指定多个编码类型时,以q值的大小排优先级,q值越大,优先级越高
//Accept-Encoding : compress;q=0.5, gzip;q=1.0 按优先级支持gzip,compress
//Accept-Encoding : * 支持所有类型
//除非显示规定identity的q值是0,如 Accept-Encoding : identity;q=0,否则identity类型始终在Accept-encoding支持的类型之内。q=0表示不可接受
//如果没有q值的定义并且支持的类型中有identity则优先返回identity类型
//如果request header里面没有定义Accept-Encoding,服务器会默认所有类型都可以被接受
//如果服务器不能返回规定的Accept-Encoding类型,则会返回406给客户端
Accept-Language:zh-CN,zh;q=0.9
//Accept-Language 表示客户端声明的它可以理解的自然语言以及优先选择的区域方言。服务端接收到这个声明,会从Accept-Language的选项中选一个然后使用Content-Language来响应通知客户端
Connection:keep-alive
//此参数决定当前事物完成之后,是否关闭连接网络连接。Keep-alive表示持续保持连接不关闭
Content-Length:0
//属于实体报头,表示发送方(客户端|服务端)发送给接收方(客户端|服务端)的消息主体的大小
Cookie:key1=value1; key2=value2;
//关于cookie的详细解释可以参考这篇文章 https://www.cnblogs.com/andy-zhou/p/5360107.html
Host:localhost:8080
Origin:http://localhost:8080
//用于标记请求来源
//只用于post请求,跨域就一定会有
//只包含host,post等信息,不会暴露参数内容
Referer:http://localhost:8080/test.jhtml?page=pagename
//用于标记请求来源
//用于所有类型的请求
//暴露参数
User-Agent:Mozilla/5.0 (Windows NT 6.1; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/63.0.3239.132 Safari/537.36
//用户代理信息,使服务器能够识别客户使用的操作系统及版本、CPU 类型、浏览器及版本、浏览器渲染引擎、浏览器语言、浏览器插件等。
X-Requested-With:XMLHttpRequest
//用于判断这个http请求是传统的http同步请求还是http ajax 异步请求
//ajax 异步请求 XMLHttpRequest
//传统http同步请求 null
//前端可以通过xhr.setRequestHeader("X-Requested-With","XMLHttpRequest")
//服务端可以通过request.getHeader("X-Requested-With")拿到这个值做进一步的的验证
一个完整的http请求分析的更多相关文章
- 一个完整的Http请求
一个完整的http请求,通常有以下7点: 1.建立tcp连接 2.web浏览器web服务器发送请求命令 3.web浏览器发送请求头信息 4.web服务器应答 5.web服务器发送应答信息 6.web服 ...
- 一个完整的 Web 请求到底发生了什么
阅读本文大概需要 7 分钟. 一.从输入一个网址开始 当我们在浏览器输入一个网址,然后按下回车,接下来浏览器显示了页面.网速好的话这之间可能就一秒,但在这一秒内到底发生了什么? 本文主要内容是试图记录 ...
- 完整的http请求分析
首先我们要明白什么是http. http:超文本传输协议(HTTP,HyperText Transfer Protocol). 超文本传输协议是互联网上应用最为广泛的一种网络协议.所有的WWW文件都必 ...
- 一个完整的HTTP请求过程详细
整个流程1.域名解析 —> 2.与服务器建立连接 —> 3.发起HTTP请求 —>4. 服务器响应HTTP请求,浏览器得到html代码 —> 5.浏览器解析html代码,并请求 ...
- 一个完整的http请求响应过程
一. HTTP请求和响应步骤 图片来自:理解Http请求与响应 以上完整表示了HTTP请求和响应的7个步骤,下面从TCP/IP协议模型的角度来理解HTTP请求和响应如何传递的. 二.TCP/IP协 ...
- 一个完整的upstart脚本分析
基本概念可以了解 http://www.mike.org.cn/articles/understand-upstart/ http://blog.fens.me/linux-upstart/ http ...
- 一个HTTP连接是包含两部分的,请求报文和响应报文这俩组合起来才是一次完整的HTTP请求,并不会单独显示请求报文或者响应报文
一个HTTP连接是包含两部分的,请求报文和响应报文这俩组合起来才是一次完整的HTTP请求,并不会单独显示请求报文或者响应报文. 2.注意看,一次HTTP请求,是包括这两部分的
- 一个简单的wed服务器SHTTPD(2)———— 客户端请求分析
//start from the very beginning,and to create greatness //@author: Chuangwei Lin //@E-mail:979951191 ...
- 【如何快速的开发一个完整的iOS直播app】(播放篇)
原文转自:袁峥Seemygo 感谢分享.自我学习 前言 在看这篇之前,如果您还不了解直播原理,请查看上篇文章如何快速的开发一个完整的iOS直播app(原理篇) 开发一款直播app,集成ijkpl ...
随机推荐
- OpenCV入门笔记(二) 图片的文件操作
以下介绍一下重要的几个,设计基本 图片处理 的函数,依次来了解OpenCV的入门知识.具体的具体使用方法还是以官方的API[Official Tutorials][Python-OpenCV]为准. ...
- 轻量级批量Omnitty工具安装和简单使用
一.Omnitty简单介绍 在实际工作需要同时对多台docker进行批量处理,为了节省时间,这个运维轻量级工具解决此问题 二.Omnitty简单按照 下载需要安装包和依赖包: omnitty-0.3. ...
- Cg入门23: Fragment shader – UV动画(序列帧)
让动画从1-9循环播放此纹理 watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQv/font/5a6L5L2T/fontsize/400/fill/I0JBQkF ...
- es的forcemerge——按照天分割
归并线程配置 segment 归并的过程,需要先读取 segment,归并计算,再写一遍 segment,最后还要保证刷到磁盘.可以说,这是一个非常消耗磁盘 IO 和 CPU 的任务.所以,ES 提供 ...
- bzoj 5017 炸弹
题目大意: 直线上有n个炸弹有坐标x和半径r 当一个炸弹被引爆时 若有炸弹的坐标在该炸弹坐标+-r范围内则另一个炸弹也被引爆 求先引爆每一个炸弹最终会引爆多少炸弹 思路: 可以想到n平方连边然后tar ...
- CF上的3道小题(1)
CF上的3道小题 终于调完了啊.... T1:CF702E Analysis of Pathes in Functional Graph 题意:你获得了一个n个点有向图,每个点只有一条出边.第i个点的 ...
- hdu 1719
Friend Time Limit: 1000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) Total Sub ...
- JavaScript-Tool:CKFinder
ylbtech-JavaScript-Tool:CKFinder 1.返回顶部 CKFinder是一个强大而易于使用的Web浏览器的Ajax文件管理器. 其简单的界面使得它直观,快速学习的各类用户,从 ...
- bzoj 2438: [中山市选2011]杀人游戏【tarjan】
没看太懂题意orz 最优的是tarjan缩点之后问入度为0的点,因为问这个点可以知道整个块的情况 答案是这ans个入度为0的点都不是杀手的概率\( \frac{n-ans}{n} \) 但是有特殊情况 ...
- 利用爬虫将Yuan先生的博客文章爬取下来
由于一次巧遇,我阅读了Yuan先生的一篇博客文章,感觉从Yuan先生得博客学到很多东西,很喜欢他得文章.于是我就关注了他,并且想阅读更多出自他手笔得博客文章,无奈,可能Yuan先生不想公开自己得博客吧 ...