请求消息(request)

客户端发送给服务器端的HTTP请求消息由请求行(requestline)请求头部(header)空行请求数据四个部分组成,如下图所示。

GET /index.html HTTP/1.1
Host: www.baidu.com
Connection: keep-alive
Upgrade-Insecure-Requests: 1
User-Agent: Mozilla/5.0 (Windows NT 10.0; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/67.0.3396.99 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, br
Accept-Language: zh-CN,zh;q=0.9
Cookie:BAIDUID=002E605A2EE0AA27D0B7C2295B9D0242:FG=1;BIDUPSID=002E605A2EE0AA27D0B7C2295B9D0242;PSTM=1532306024;BD_UPN=12314753;BDORZ=B490B5EBF6F3CD402E515D22BCDA1598;delPer=0;BD_HOME=0;H_PS_PSSID=1465_26911_21121_26350_26925_20719

第一部分:请求行,用来说明请求类型,要访问的资源以及所使用的HTTP版本.

请求行以一个方法符号开头,以空格分开,后面跟着请求的URI和协议的版本。GET指定请求类型为GET,/index.html为要访问的资源,该行的最后一部分说明使用的是HTTP1.1版本。

第二部分:请求头部,紧接着请求行(即第一行)之后的部分,用来说明服务器要使用的附加信息。

从第二行起为请求头部,HOST将指出请求的目的地。User-Agent,服务器端和客户端脚本都能访问它,它是浏览器类型检测逻辑的重要基础.该信息由你的浏览器来定义,并且在每个请求中自动发送等等。

第三部分:空行,请求头部后面的空行是必须要有的

即使第四部分的请求数据为空,也必须有空行。

第四部分:请求数据也叫主体,可以添加任意的其他数据。

这个例子的请求数据为空。

POST请求例子,使用Charles抓取的request:

POST /api/students HTTP/1.1
Host: 192.168.0.130:3000
Connection: keep-alive
Content-Length: 245
Cache-Control: max-age=0
Origin: http://192.168.0.130:3000
Upgrade-Insecure-Requests: 1
Content-Type: application/x-www-form-urlencoded
User-Agent: Mozilla/5.0 (Windows NT 10.0; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/67.0.3396.99 Safari/537.36
Accept:text/html,application/xhtml+xml,application/xml;q=0.9,image/webp,image/apng,*/*;q=0.8
Referer: http://192.168.0.130:3000/students/create
Accept-Encoding: gzip, deflate
Accept-Language: zh-CN,zh;q=0.9clazz=%E7%81%AB%E8%8A%B112%E6%9C%9F&name=%E9%99%88%E6%A2%A6%E9%BE%99&gender=%E7%94%B7&age=20&hobby=%E7%9D%A1%E8%A7%89&hobby=%E6%89%93%E8%B1%86%E8%B1%86&tel=13834569928&address=%E5%8D%97%E9%98%B3&remark=%E6%96%B0%E5%90%8C%E5%AD%A6   --------》(请求数据)

第一部分:请求行,第一行明了是post请求,以及http1.1版本。
第二部分:请求头部,第二行至第六行。
第三部分:空行,第七行的空行。
第四部分:请求数据,第八行。

响应消息(response)

一般情况下,服务器接收到请求后,会对请求进行处理,然会返回给客户端一个HTTP的响应消息。HTTP响应也由四个部分组成,分别是:状态行、响应头、空行和响应正文

HTTP/1.1 200 OK
Bdpagetype: 1
Bdqid: 0xc347763400004282
Cache-Control: private
Connection: Keep-Alive
Content-Encoding: gzip
Content-Type: text/html
Cxy_all: baidu+5e802392ce41b42ad2771898f1006759
Date: Thu, 09 Aug 2018 01:36:14 GMT
Expires: Thu, 09 Aug 2018 01:36:06 GMT
Server: BWS/1.1
Set-Cookie: delPer=0; expires=Sat, 01-Aug-2048 01:36:06 GMT
Set-Cookie: BDSVRTM=0; path=/
Set-Cookie: BD_HOME=0; path=/
Set-Cookie: H_PS_PSSID=1465_26964_21121_26350_26925_20719;path=/;domain=.baidu.com Strict-Transport-Security: max-age=172800
Vary: Accept-Encoding
X-Ua-Compatible: IE=Edge,chrome=1
Transfer-Encoding: chunked<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8" /><title>百度一下</title>
</head>
<body>文档内容。。。
</body>
</html>

第一部分:状态行,由HTTP协议版本号, 状态码, 状态消息 三部分组成。

第一行为状态行,(HTTP/1.1)表明HTTP版本为1.1版本,状态码为200,状态消息为(ok)

第二部分:消息报头,用来说明客户端要使用的一些附加信息

第二行和第三行为消息报头,Date:生成响应的日期和时间;Content-Type:指定了MIME类型的HTML(text/html),编码类型是UTF-8

第三部分:空行,消息报头后面的空行是必须的

第四部分:响应正文,服务器返回给客户端的文本信息。

空行后面的html部分为响应正文。

ajax——请求消息(request)和响应消息(response)相关推荐

  1. http请求消息体和响应消息体

    HTTP基于请求与响应模式的.无状态的.应用层的协议,常基于TCP的连接方式.HTTP允许传输任意类型的数据对象,HTTP协议是无状态协议.无状态是指协议对于事务处理没有记忆能力.缺少状态意味着如果后 ...

  2. ajax和flash,flask ajax请求后flash方法(消息闪现)无效问题的解决方法

    一.问题描述 一个好的应用和用户界面需要良好的反馈,flask的消息闪现系统提供了一个良好的反馈方式.闪现系统的基本工作方式是:在且只在下一个请求中访问上一个请求结束时记录的消息. 正常使用flash ...

  3. PHP和ajax请求_「jQuery+PHP」ajax请求以及接口PHP响应教程

    各位客官好,平时我们在开发时,不可避免的会用到Ajax与后台做数据交互,那么今天小编今天就给各位没有用过Ajax的客官以及准备接触的客官讲解一下,并且小编会为大家讲一下请求时的loading层等待以及 ...

  4. Express HTTP请求中的请求消息(req)和响应消息(res)

    本文摘抄自菜鸟教程 Express 4.x API中文文档 Request req 对象代表了一个HTTP请求,其具有一些属性来保存请求中的一些数据,比如query string,parameters ...

  5. javaweb实现文件下载用ajax请求,浏览器无响应的问题

    最近做公司项目要实现用户通过浏览器从服务端下载文件的功能.于是,我写好了后台,然后前端用JQuery的ajax()方法发送请求到后台,按道理说是没有问题的,包括相应头的设置都没问题,但是点击下载按钮过 ...

  6. Python爬虫学习之API与模拟ajax请求

    API的使用 --通过API向服务器请求数据 优点:简单直接,高效率地批量爬取:解决动态网页的爬取. 缺点:通过API的缺点是有些网站会限制API调用的次数和频率,用户需要付费来升级成高级用户来获取更 ...

  7. 判断是否Ajax请求

    http://zwllxs.iteye.com/blog/1070429 在一次做非常复杂的ajax应用时,如果一个会话已经超时,但是此时再通过ajax请求,那么ajax返回的则是一个登陆页面的htm ...

  8. 怎么样给ajax的ulr加密,研究Ajax请求受登录保护的URL的优雅解决

    在此先记下思路. 场景:登录页面login,在一个登录后才能访问的页面dashboard,dashboard上有一个按钮button,button绑定了一个单击事件,触发后发出一个ajax请求,aja ...

  9. ajax ssm 页面跳转_Shiro 教程,Ajax请求拦截跳转页面方案

    我们知道Ajax不能做页面redirect和forward跳转,所以Ajax请求假如没登录,那么这个请求给用户的感觉就是没有任何反应,而用户又不知道用户已经退出或是  Session  超时了.这个时 ...

  10. jquery的ajax全局事件和AJAX 请求正在进行时显示“正在加载”

    实例 当 AJAX 请求正在进行时显示"正在加载"的指示: $("#txt").ajaxStart(function(){$("#wait" ...

最新文章

  1. c++中的基本知识点
  2. visualStudio创建项目过程
  3. 微信小程序搜索功能!附:小程序前端+PHP后端
  4. java防止库存超买_java初探(1)之防止库存为负以及防超买
  5. wxWidgets:wxWizardEvent类用法
  6. 1.const关键字.rs
  7. Java内存模型解析
  8. 网络知识:秒懂你家的网络连接方式
  9. jsp mysql 插入数据_jsp连接MySQL实现插入insert操作功能示例
  10. cisco6509 2811 配置备份
  11. Android学习之Android 5.0分享动画实现微信点击全屏效果
  12. ubantu 安装anaconad_Ubuntu16.04安装Anaconda (转)
  13. 计算机常见故障判断与排除,电脑常见故障诊断与排除从新手到高手
  14. SmartUpload出现的问题
  15. 吴恩达深度学习笔记(五)
  16. Shader特效之图片波动炫光效果
  17. Android OCR数字识别
  18. vivo S16/S15/S12/S10 PRO卡刷线刷系统升级降级推荐成功解决屏幕锁不记得开机锁成功刷好的有效方案
  19. 进gmail不失去连接的办法之一
  20. 验证码可以说是爬虫中比较麻烦的技术了!今天教你搞定滑块验证码!

热门文章

  1. ESP32 学习笔记(二十二)睡眠模式
  2. 领航优配|货拉拉冲刺港交所:2022年首度盈利,闭环交易总额全球第一
  3. 【秋招面试】货拉拉面试(1面过程)
  4. 计算机怎样同时运行多个程序的?进程相关概念介绍
  5. java中画图喷枪_JAVA 画图板实现(基本画图功能+界面UI)一、界面实现
  6. 华为防火墙路由模式配置(三)
  7. 登录页面,登录后跳转不成功
  8. 什么 ? 陪玩都月入过忘拉~这不得python采集一下
  9. 24.请编写一个函数fun,它的功能是:将一个数字字符串转换为一个整数(不得调用C语言提供的将字符串转换为整数的函数)。
  10. android开发截屏代码,android截屏代码:C++实现