在开始前,我们首先对HTTP协议做个简单的了解

HTTP协议(Hyper Text Transfer Protocol) 超文本传输协议

名词非常的高大上,如果学过计算机网络这门课(再如果还有一点印象...)会知道这是应用层的协议,应用层对应在OSI/ISO七层模型的最顶层,
是直接对接应用程序提供服务的,HTTP协议是TCP/IP的高级协议,默认端口是80,每个请求会对应一个响应
举个简单的例子那就是,我们在网上冲浪的时候就使用到了HTTP协议,那么HTTP到底定义了什么?

* 概念:
  HTTP协议定义了浏览器与服务器之间通信时,发送数据的格式。这是一种约定,而我们今天讲的Request请求就是浏览器在向服务器端传送数据时需要遵守的格式


一个HTTP请求会包含三部分
1.请求行
2.请求头
3.请求体

下面我们逐个来说

请求行

请求行组成的格式是: 请求方式-URL-协议/版本
  给出一个例子: GET /request/demo1 HTTP/1.1

HTTP1.1请求提供了七种请求方式,分别是GET、POST、HEAD、OPTIONS、PUT、DELETE以及Trace,我们这里着重说下用的比较多的两种 GETPOST

GET请求方式的特点是:
  1.请求参数列表直接附加在URL后面,什么是请求参数列表呢?这个我们待会以例子来说
  2.请求的url是有长度限制的
  3.由于参数是直接附加在URL后面的,所以相对来说没那么安全

POST请求方式的特点是:
  1.请求参数列表封装在请求体中
  2.请求的url没有长度的限制
  3.由于参数是封装在请求体中,相对来说会比较安全


GET请求方式多用于查询,就像我们平常在搜索引擎查询想要查询的信息的时候,就是属于GET请求方式

POST请求方式多用于提交信息,就像我们平常在页面输入账号密码登录一样,就是使用POST请求方式


请求头

 *概念:客户端浏览器告诉服务器端一些信息,这里面的格式是以键值对形式出现的(请求头名称:请求头值),下面介绍几个请求头,
有兴趣的可以自行去查资料

  1.User-Agent:浏览器告诉服务器,我访问你使用的浏览器版本信息

    举个例子:

 User-Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/78.0.3904.108 Safari/537.36
User-Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64; rv:70.0) Gecko/20100101 Firefox/70.0

  这其中涉及了一段浏览器大战的历史渊源,感兴趣的朋友自行去查资料。

  这里我们注意一个就好了,Chrome和Firefox,没错这就是两个从谷歌浏览器和火狐浏览器访问同一个url得到的User-Agent,明确告诉了服务器我是属于那个浏览器
的,后面附带的自然就是浏览器版本号

  2.Accpet: 告诉服务器,客户端可以处理的内容类型

  
  3.Accpet-Encoding:告诉服务器端,客户端能够理解的内容编码方式,一般都是一些压缩的算法

  4.Host:指明了服务器的域名,以及服务器监听的TCP端口,例如我们输入www.baidu.com,就是在访问百度的服务器


最后说一下请求体,(需要知道的是请求头与请求体之间存在一行请求空行,作用是分割请求头和请求体)


请求体也叫做请求正文,举个简单的例子来说

<form action="#">
用户名:<input type="text" name="username"> <br>
密码:<input type="password" name="password"><br> <input type="submit" value="登录"> </form>

上文讲到了请求参数列表,那它究竟是什么呢?从这个表单我们可以看出两个用户名和密码两个input标签里均有一个名为name的属性,注意看图



form表单默认的请求方式就是GET,所以我们会看到这username和password直接附加在url中了,此时username和password就是我们讲的请求参数列表,当然实际上会有很多,这里这是简单的举个”梨子“

所以请求行的格式就是:请求参1名称=请求参数1值&请求参数2名称=请求参数2值 .... 注意参数列表间使用 ‘&’ 做分隔符


最后给出一个完整的HTTP请求字符串表示形式

GET /web/login.html HTTP/1.1
Accept: text/html,application/xhtml+xml,application/xml;q=0.9,image/webp,image/apng,*/*;q=0.8,application/signed-exchange;v=b3
Accept-Encoding: gzip, deflate, br
Accept-Language: zh-CN,zh;q=0.9
Connection: keep-alive
Cookie: Idea-2879242d=1fa6d102-fd6b-460f-8142-83f5d129d205; JSESSIONID=66D836411246ACA9410EF12C6BA75065
Host: localhost:63342
If-Modified-Since: Thu, 28 Nov 2019 03:59:44 GMT
Sec-Fetch-Mode: navigate
Sec-Fetch-Site: same-origin
Sec-Fetch-User: ?1
Upgrade-Insecure-Requests: 1
User-Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/78.0.3904.108 Safari/537.36 username=Amg997&password=123

至此,HTTP协议学习之Request学习就讲完了...

HTTP协议学习之Request学习的更多相关文章

  1. MQTT协议实现Eclipse Paho学习总结二

    一.概述 前一篇博客(MQTT协议实现Eclipse Paho学习总结一) 写了一些MQTT协议相关的一些概述和其实现Eclipse Paho的报文类别,同时对心跳包进行了分析.这篇文章,在不涉及MQ ...

  2. MQTT协议实现Eclipse Paho学习总结

    MQTT协议实现Eclipse Paho学习总结 摘自:https://www.cnblogs.com/yfliufei/p/4383852.html 2015-04-01 14:57 by 辣椒酱, ...

  3. JavaWeb 后端 <三> 之 Response Request 学习笔记

    一.响应对象 Response(重点:HTTP协议响应部分) 查看

  4. #学习笔记#e2e学习使用(一)

    本文仅限于记录本人学习的过程,以及怎么踩的坑,是如何解决的.逻辑肯定是混乱的,有用之处会抽出共通另行发帖. 最终目标:要运用于Vue项目中,进行功能测试甚至自动化测试. 一.e2e概念 理解:end ...

  5. 2019最新WEB前端开发小白必看的学习路线(附学习视频教程)

    2019最新WEB前端开发小白必看的学习路线(附学习视频教程).web前端自学之路:史上最全web学习路线,HTML5是万维网的核心语言,标准通用标记语言下的一个应用超文本标记语言(HTML)的第五次 ...

  6. 20155234 2016-2017-2第十周《Java学习笔记》学习总结

    20155234第十周<Java学习笔记>学习总结 教材学习内容总结 网络编程 在两个或两个以上的设备(例如计算机)之间传输数据.程序员所作的事情就是把数据发送到指定的位置,或者接收到指定 ...

  7. 20155234 2610-2017-2第九周《Java学习笔记》学习总结

    20155234第九周<Java学习笔记>学习总结 教材学习内容总结 数据库本身是个独立运行的应用程序 撰写应用程序是利用通信协议对数据库进行指令交换,以进行数据的增删查找 JDBC(Ja ...

  8. Vue学习笔记-rest_framework_jwt 学习

    一  使用环境 开发系统: windows 后端IDE: PyCharm 前端IDE: VSCode 数据库: msyql,navicat 编程语言: python3.7  (Windows x86- ...

  9. (转)Predictive learning vs. representation learning 预测学习 与 表示学习

    Predictive learning vs. representation learning  预测学习 与 表示学习 When you take a machine learning class, ...

随机推荐

  1. 洛谷 P3951 NOIP 2017 小凯的疑惑

    洛谷 P3951 NOIP 2017 小凯的疑惑 题目描述 小凯手中有两种面值的金币,两种面值均为正整数且彼此互素.每种金币小凯都有 无数个.在不找零的情况下,仅凭这两种金币,有些物品他是无法准确支付 ...

  2. 用Python的Pandas和Matplotlib绘制股票KDJ指标线

    我最近出了一本书,<基于股票大数据分析的Python入门实战 视频教学版>,京东链接:https://item.jd.com/69241653952.html,在其中给出了MACD,KDJ ...

  3. Trie详解

    Trie,又名字典树.单词查找树,可以较高效地实现统计.排序和保存大量的字符串. 顾名思义,Trie是一个树状的结构,按照树型结构来存储字符串,显然是一种以空间换时间的方法.整体上理解和实现都不会很难 ...

  4. source insight4提示结尾不一致。关闭

    source insight4提示结尾不一致.关闭.世界清静了. Options -> Preferences ->Files  最后的Ask to fix inconsistent li ...

  5. Blazor带我重玩前端(六)

    本文主要讨论Blazor事件内容,由于blazor事件部分很多,所以会分成上下两篇,本文为第二篇. 双向绑定 概述 如图所示 当点击单项绑定的时候,MyOnewayComponent里的属性值会发生变 ...

  6. 微信小程序|小游戏

    [官]小游戏开发 https://developers.weixin.qq.com/minigame/dev/index.html 官网 https://mp.weixin.qq.com 做了4个微信 ...

  7. 1.spring boot初始化项目

    初始化spring boot项目的方式非常多,如使用Spring Tool Suite.使用IntelliJ IDEA.使用NetBeans.在start.spring.io网站中.curl命令.sp ...

  8. 再试Count(*) 与Count(*) 列

    试问,如果有一张表有两个字段,均可为空,插入两条首个字段为空的记录,再插入两条第二字段为空的记录,问count(*)和count(列)结果如何? 答案:count(*)是正常的四条,而count(列) ...

  9. Asp.Net中的三种分页方式总结

    本人ASP.net初学,网上找了一些分页的资料,看到这篇文章,没看到作者在名字,我转了你的文章,只为我可以用的时候方便查看,2010的文章了,不知道这技术是否过期. 以下才是正文 通常分页有3种方法, ...

  10. ES 实现实时从Mysql数据库中读取热词,停用词

    IK分词器虽然自带词库 但是在实际开发应用中对于词库的灵活度的要求是远远不够的,IK分词器虽然配置文件中能添加扩展词库,但是需要重启ES 这章就当写一篇扩展了 其实IK本身是支持热更新词库的,但是需要 ...