每日分享:

不要垂头丧气,即使失去一切,明天仍在你手里。

目录:

  1. HTTP协议
  2. URL
  3. 查看HTTP协议的通信过程
  4. HTTP请求报文
  5. HTTP响应报文

一、HTTP协议

1. HTTP协议的介绍

HTTP协议(HyperText Transfer Protocol):超文本传输协议

超文本是超级文本的缩写,是指超越文本限制或者超链接,比如图片、音乐、视频、超链接等等都属于超文本。

HTTP协议之前的目的是传输网页数据的,现在允许传输任意类型的数据

传输HTTP协议格式的数据是基于TCP传输协议的,发送数据之前需要建立连接

2. HTTP协议的作用

它规定了浏览器和Web服务器通信数据的格式,也就是说浏览器和Web服务器通信需要使用HTTP协议

3. 浏览器访问web服务器的通信过程

4. 小结

  • HTTP协议是一个超文本传输协议
  • HTTP协议是一个基于TCP传输协议传输数据的
  • HTTP协议规定了浏览器和web服务器通信数据的格式

二、URL

1. URL的概念

URL(Uniform Resoure Locator),表达的意思是统一资源定位符,通俗理解就是网络资源地址,也就是我们常说的网址

2. URL的组成

URL的样子:

https://news.163.com/18/1122/10/E178J2O4000189FH.html

URL的组成部分:

  1. 协议部分:https://、http://、ftp://
  2. 域名部分:news.163.com
  3. 资源路径部分:/18/1122/10/E178J2O4000189FH.html

域名:

域名就是IP地址的别名,它是用点分割使用英文字母和数字组成的名字,使用域名目的就是方便的记住某台主机IP地址

URL的扩展:

https://news.163.com/hello.html?page=1&count=10

  • 查询参数部分:?page=1&count=10

参数说明:

  • ?后面的page表示第一个参数,后面的参数都使用&进行连接

3. 小结

  • URL就是网络资源的地址,简称网址,通过URL能够找到网络中对应的资源数据
  • URL组成部分
  1. 协议部分
  2. 域名部分
  3. 资源路径部分
  4. 查询参数部分(可选)

三、查看HTTP协议的通信过程

1. 谷歌浏览器开发者工具的使用

右键->检查(或者快捷键F12)

 开发者工具标签选项说明:

  • 元素(Elements):用于查看或修改HTML标签
  • 控制台(Console):执行js代码
  • 源代码(Sources):查看静态资源文件,断点调试JS代码
  • 网络(Network):查看http协议的通信过程

开发者工具使用效果图:

开发者工具的使用说明:

  1. 点击Network标签选项
  2. 在浏览器的地址栏输入百度的网址,就能看到请求百度首页的http的通信过程
  3. 这里的每项记录都是请求+响应的一次过程

2. 查看HTTP协议的通信过程

查看HTTP请求信息的效果图:

3. 小结

  • 谷歌浏览器的开发者工具是查看http协议的通信过程利器,通过Network标签选项可以查看每一次请求和响应的通信过程,调出开发者工具的通用方法:右键->检查
  • 开发者工具的Headers选项总共有三部分组成:
  1. General:主要信息
  2. Response Headers:响应头
  3. Request Headers:请求头
  • Response选项是查看响应体信息的

四、HTTP请求报文

1. HTTP请求报文介绍

HTTP最常见的请求报文有两种:

  1. GET方式请求报文
  2. POST方式的请求报文

说明:

  • GET:获取web服务器数据
  • POST:向web服务器提交数据

2. HTTP GeT 请求报文分析

HTTP GET请求报文:

---------- 请求行 -----------

GET / HTTP/1.1         GET请求方式   请求资源路径   HTTP协议版本

---------- 请求头 -----------

Host: www.itcast.cn     服务器的主机地址和端口号,默认是80

Connection: keep-alive    和服务器保持长连接

Cache-Control: max-age=0    缓存头,指定缓存机制

Upgrade-Insecure-Requests: 1    浏览器升级不安全请求,使用 https请求

User-Agent: Mozilla/5.0……       用户代理,也就是客户端名称

Accept:text/html,application/xhtml+xml,application/xml;q=0.9,image/avif,image/webp,image/apng,*/*;q=0.8,application/signed-exchange;v=b3;q=0.9                 可接受的数据类型

Accept-Encoding: gzip, deflate         可接受的压缩格式

Accept-Language: zh-CN,zh;q=0.9    可接受的语言

Cookie: UM_distinctid=17d3c435deb834……   登录用户的身份标识

---------- 空行 -----------

GET请求原始报文:

GET / HTTP/1.1\r\n

Host: www.itcast.cn\r\n

Connection: keep-alive\r\n

Cache-Control: max-age=0\r\n

Upgrade-Insecure-Requests: 1\r\n

User-Agent: Mozilla/5.0……\r\n

Accept:text/html,application/xhtml+xml,application/xml;q=0.9,image/avif,image/webp,image/apng,*/*;q=0.8,application/signed-exchange;v=b3;q=0.9\r\n

Accept-Encoding: gzip, deflate\r\n

Accept-Language: zh-CN,zh;q=0.9\r\n

Cookie: UM_distinctid=17d3c435deb834……\r\n

\r\n(请求头信息后面还有一个单独的‘\r\n’不能省略)

说明:

每项数据之间使用:\r\n

3. HTTP POST请求报文分析

HTTP POST请求报文(部分截图):

请求体效果图(部分截图):

POST比GET最后(空行后)多了一个请求体,其余相同

4. 小结

  • 一个HTTP请求报文可以由请求行、请求头、空行和请求体4个部分组成
  • 其中请求行由三部分组成:
  1. 请求方式
  2. 请求资源路径
  3. HTTP协议版本
  • GET方式的请求报文没有请求体,只有请求行、请求头、空行组成
  • POST方式的请求报文可以有请求行、请求头、空行、请求体四部分组成

五、HTTP响应报文

1. HTTP响应报文分析2.

HTTP响应报文部分截图:

2. HTTP状态码介绍

HTTP状态码是用于表示web服务器响应状态的3位数字代码

状态码 说明
200 请求成功
307 重定向
400 错误的请求,请求地址或参数有误
404 请求资源在服务器不存在
500 服务器内部源代码出现错误

说明:

307:重定向(它更改了你的请求地址)

例:

访问http://www.baidu.com它会给你重定向为http://www.baidu.com

3. 小结

  • 一个HTTP响应报文是由响应行、响应头、空行和响应体4个部分组成
  • 响应行是由三部分组成:HTTP协议版本状态码状态描述,其中状态码200最常见

web中HTTP协议详解相关推荐

  1. WebRTC中RTP协议详解

    WebRTC中RTP协议详解 WebRTC中RTP协议详解 WebRTC中RTP协议详解 前言 一.RTP/RTCP在协议栈中的位置 1. RTP传输流程图 二.RTP Header 的结构图 1.R ...

  2. web和http协议-详解

    1.1 HTTP服务的重要基础 1.1.1 用户访问网站基本流程 我们每天都会使用Web客户端上网浏览网页.最常见的Web客户端就是Web浏览器,如通用的微软Internet Explorer ( I ...

  3. web中网络编程详解

    今天是冬至,不知道大家有没有吃饺子啊! 每日分享: 冬至是北半球一年之中夜晚最长的一天,愿你在这个长夜能融化掉这一年所有的不快乐!! 目录: IP地址的介绍 端口和端口号的介绍 TCP的介绍 sock ...

  4. 大数据WEB阶段(八)Tomcat服务器安装与详解、HTTP协议详解

    Tomcat 一. 服务器 动态web资源运行需要服务器环境 客户端发送请求到服务器 , 服务器调用动态web资源 Servlet容器 . web容器 .服务器 Servlet容器 java中的动态资 ...

  5. SSL/TLS协议详解(中)——证书颁发机构

    SSL/TLS协议详解(中)--证书颁发机构 本文翻译自:https://www.wst.space/ssl-part-3-certificate-authority/ 上一篇中,我们讨论了关于Dif ...

  6. Web协议详解与抓包实战之HTTP1.1 学习笔记【一】

    Web协议详解与抓包实战之HTTP1.1[一] 前言 <Web协议详解与抓包实战>课程学习,陶辉老师主讲 学习内容: HTTP–TLS/SSL–TCP/IP自上而下根据应用学习web协议H ...

  7. Spring中,applicationContext.xml 配置文件在web.xml中的配置详解

    Spring中,applicationContext.xml 配置文件在web.xml中的配置详解 2016年10月04日 15:22:26 阅读数:7936 转自http://www.cnblogs ...

  8. HTTP协议详解(真的很经典)

    转自:http://blog.csdn.net/gueter/archive/2007/03/08/1524447.aspx Author :Jeffrey 引言 HTTP是一个属于应用层的面向对象的 ...

  9. Http 协议详解笔记

    HTTP是一个属于应用层的面向对象的协议,由于其简捷.快速的方式,适用于分布式超媒体信息系统.它于1990年提出,经过几年的使用与发展,得到不断地完善和扩展.目前在WWW中使用的是HTTP/1.0的第 ...

  10. Http协议 详解(转载)

    http://blog.csdn.net/gueter/archive/2007/03/08/1524447.aspx 引言 HTTP是一个属于应用层的面向对象的协议,由于其简捷.快速的方式,适用于分 ...

最新文章

  1. vs2008 试用版评估期结束的解决方法(2009-08-
  2. 根据mysql数据库日志恢复删除数据
  3. qt designer 插入图片_真的不错,宁波棉服图片
  4. idea报错Class not found (在target中没有生成对应的class文件)
  5. [Java基础]Lambda表达式练习
  6. (转)ThreadPoolExecutor最佳实践--如何选择队列
  7. spring的钩子_高级java开发必须掌握的Spring接口——SmartLifecycle
  8. 辐射避难所买了东西显示服务器异常,《辐射:避难所》常见问题汇总
  9. 2021年中国新经济企业500强发展研究报告
  10. mysql使用中文报错,hibernate mysql 插入中文错误
  11. 【Hive】hive表的文件存储格式
  12. Day11名称空间,作用域,闭包函数
  13. Linux 命令 速记
  14. OpenCV 图像编解码操作【imencode/imdecode】使用
  15. 谷粒商城 Day04 sku与spu接口
  16. ETH开发 JSONRPC
  17. sqli-labs靶场第八关
  18. \t\t长痘痘(鼻尖,脸上等部位)的原因,应该怎么办?
  19. 姜小白的Python日记Day5 字符串与字典
  20. react 或者 vue,如何做 SEO 优化?

热门文章

  1. C语言笔试题与答案解析
  2. 软件工程导论习题集 | 170道选择 | 50道填空 | 40道简答 | 其他试卷资源
  3. IT战略规划与企业架构
  4. linux看门狗机制
  5. 小程序界面设计难?有了这个高颜值UI,我带你一步步解决所有难题
  6. 已解决:关于navicat premium数据库激活一直不成功的解决方法
  7. linux桌面共享编程,Remmina:一个Linux下功能丰富的远程桌面共享工具
  8. 状态机,从细节出发(一段式、两段式、三段式,moore型、mealy型)
  9. URL 和 URI 区别
  10. 傅里叶变换到拉普拉斯变换及收敛域分析