Http 协议概述| 学习笔记

简介: 快速学习 Http 协议概述,介绍了 Http 协议概述系统机制, 以及在实际应用过程中如何使用。

开发者学堂课程【Java Web 开发-Web 应用、Tomcat、HTTP 请求与响应Http 协议概述】学习笔记,与课程紧密联系,让用户快速学习知识。

课程地址:https://developer.aliyun.com/learning/course/575/detail/7963


Http 协议概述

 

内容简介:

一、Http 协议的概述

二、安装 HttpWatch

三、请求协议

四、响应协议


一、Http 协议的概述

协议:协议的甲乙双方,就是客户端(浏览器)和服务器!意思就是怎么请求,和怎么响应。在网络中传输的只有一样东西就是字节,看懂字节的意思。

HTTP 也可以理解成双方通信格式,就是一个通信规则。通信规则规定了客户端发送给服务器的内容格式,也规定了服务器发送给客户端的内容格式。

其实我们要学习的就是这个两个格式!客户端发送给服务器的格式叫“请求协议”;服务器发送给客户端的格式叫“响应协议”。

HTTP(hypertext transport protocol) ,即超文本传输协议。请求和响应都要和超文本相关,是带超链接的文本。超文本标记语言,用来编写超文本的一门标记语言。标记就是标签。这个协议详细规定了浏览器和万维网服务器之间互相通信的规则。

在浏览器中输入地址:http://www.baidu.com/进行请求。点击右键查看源代码是服务器给我们发过来内容的一部分。这一部分被称为响应体,或者被称为响应正文。以写信格式为例,除了正文以外,前面和后面的部分(开头和此致敬礼)都没有看见。

我们想看见这些地方,就需要一些小工具。得到浏览器发给服务器的东西和服务器响应回来的内容。IE 可以安装这个,叫做 HttpWatch。他就可以帮我们完成这个事情。


二、安装 HttpWatch

HttpWatch 是专门为 IE 浏览器提供的,用来查看 HTTP 请求和响应内容的工具。而 FireFox 上需要安装 FireBug 软件。

如果你使用的是 Chrome ,那么就不用自行安装什么工具了,因为它自身就有查看请求和响应内容的功能!

Http Watch 和 FireBug 这些工具对浏览器而言不是必须的,但对我们开发者是很有帮助的,通过查看 HTTP 请求响应内容,可以使我们更好的学习 HTTP 协议。

安装过程可以查看文档,一直一直下一步即可。安装成功后,打开 IE。

image.png

image.png

打开浏览器,输入访问地址:

http://localhost:/hello3/index.jsp

访问结果为:

Hello3

点击如图所示的标志

image.png

点击录制 Record,此时才可以开始工作。

重新访问地址:http://localhost/hello3/index.jsp

左边是浏览器发给服务器的东西。右边是服务器发给浏览器的。

 

三、请求协议

1.请求的格式:

请求行

多个请求头信息:头名称:头值

空行

请求体

GET/hello3/index.jsp   HTTP/1. 1

Accept:application/x-ms-application,image/jpe*/*

Accept-Language:zh-CN,en-US;q=0. 5;

User-Agent: Mozilla/4. 0 (compatible;MSIE 8.0)

Accept-Encoding:gzip, deflate

Host:localhost

Connection: Keep-Alive

2.说明如下:

Get 请求没有请求体,但永远有空行。

Accept 表示浏览器支持哪些资源类型,*/*表示什么都支持。

Accept-Language 表示支持的语言,浏览器语言自己可以设置,浏览器只关心第一个 zh-CN,第二个 en-US 是备注的,第一个的优先级高。

User-Agent 把我们操作系统的型号,品牌,浏览器的品牌,型号告诉服务器。一般服务器不会查看,所做的响应都一样,但是少部分东西因为浏览器存在差异造成服务器有时需要判断,客户端用的是什么浏览器,然后做相应的响应。

为了对待不同的浏览器需要不同的响应,User-Agent 就可以获取浏览器信息。

Accept-Encoding 支持编码,gzip 压缩格式,数据在发送的时候需要压缩才能更好,可以节省空间。

压缩数据不能直接读取,还需要解压,表示服务器可以发送 gzip 压缩后的东西给浏览器,然后浏览器自行解压。

Host 表示请求的主机是 localhost,localhost 和 /hello3/index.jsp ,构成了访问路径。

HTTP/1. 1 表示协议版本。

Http 协议是一种无状态协议。当发出一个请求,响应结束,再次进行请求时,Http 协议并不知道上一次的协议请求。

Http 请求占用资源特别少,断开之后的请求并不会走流量,不会占用网络,将网线拔掉后,页面也不会消失,页面已经下载到浏览器,与服务器无关。

有状态协议表示第一次请求紧跟着后面的请求都知道。ftp 协议是有状态协议。

Connection: Keep-Alive 连一小会儿,目的是不浪费刚刚连接的资源,断开后在连接很麻烦。它起的作用就是将一个页面上所有的请求都用一个连接完成,节省资源。

 

四、响应协议

1. 响应的格式

响应行(协议/版本 状态码 状态码的解析)

响应头( key/value 格式)

空行

响应正文

HTTP/1. 1 200 OK

Server: Apache-Coyote/1. 1

Set-Cookie: JSESSIONID=48F75E08BD4DF3C3E72919543CBFDF81; Path=/he11o3/: Httponly

Content-Type:text/html;charset=IS0-8859-1

Content-Length: 646

Date: Thu, 22 May 2014 06: 45: 26 GMT

2.说明如下

OK 是对200的解释,即请求成功。状态码以“2”开头算请求成功,以“3”开头全要转接,以“4”开头全是客户端的错误,以“5”开头是服务器的错误。

text/html:text 是文本,表示文本的类型为 html ;

如果是图片 Content-Type:image/gif ,写到这里即完成。

若是文本,后面还需要加分号加编码,任何文本都需要有编码,只告诉文本不给编码,是读不了的。

Content-Type: 响应内容的 MIME 类型。

Content-Length 表示字节数。

相关文章
|
1月前
|
网络协议 网络安全 数据安全/隐私保护
HTTP 协议浅析
通过对HTTP协议的深入了解,开发者可以更好地设计和优化Web应用,提高数据传输效率和用户体验。
133 21
|
2月前
|
缓存 网络协议 前端开发
Web 性能优化|了解 HTTP 协议后才能理解的预加载
本文旨在探讨和分享多种预加载技术及其在提升网站性能、优化用户体验方面的应用。
Web 性能优化|了解 HTTP 协议后才能理解的预加载
|
2月前
|
XML JSON 前端开发
HTTP协议,Content-Type格式介绍篇
通过理解和正确使用Content-Type头字段,可以确保数据在网络上传输时的正确性和高效性,提升网络应用的可靠性和用户体验
160 28
|
2月前
|
XML JSON 前端开发
HTTP协议,Content-Type格式介绍篇
通过理解和正确使用Content-Type头字段,可以确保数据在网络上传输时的正确性和高效性,提升网络应用的可靠性和用户体验。
306 25
|
2月前
|
XML JSON 前端开发
HTTP协议,Content-Type格式介绍篇
通过理解和正确使用Content-Type头字段,可以确保数据在网络上传输时的正确性和高效性,提升网络应用的可靠性和用户体验。
354 18
|
3月前
|
域名解析 缓存 网络协议
Web基础与HTTP协议
通过掌握这些基础知识和技术,开发者可以更加高效地构建和优化Web应用,提供更好的用户体验和系统性能。
104 15
|
3月前
|
前端开发 网络协议 安全
【网络原理】——HTTP协议、fiddler抓包
HTTP超文本传输,HTML,fiddler抓包,URL,urlencode,HTTP首行方法,GET方法,POST方法
|
4月前
|
Dubbo 安全 应用服务中间件
Apache Dubbo 正式发布 HTTP/3 版本 RPC 协议,弱网效率提升 6 倍
在 Apache Dubbo 3.3.0 版本之后,官方推出了全新升级的 Triple X 协议,全面支持 HTTP/1、HTTP/2 和 HTTP/3 协议。本文将围绕 Triple 协议对 HTTP/3 的支持进行详细阐述,包括其设计目标、实际应用案例、性能测试结果以及源码架构分析等内容。
327 10
|
3月前
|
网络协议 安全 网络安全
探索网络模型与协议:从OSI到HTTPs的原理解析
OSI七层网络模型和TCP/IP四层模型是理解和设计计算机网络的框架。OSI模型包括物理层、数据链路层、网络层、传输层、会话层、表示层和应用层,而TCP/IP模型则简化为链路层、网络层、传输层和 HTTPS协议基于HTTP并通过TLS/SSL加密数据,确保安全传输。其连接过程涉及TCP三次握手、SSL证书验证、对称密钥交换等步骤,以保障通信的安全性和完整性。数字信封技术使用非对称加密和数字证书确保数据的机密性和身份认证。 浏览器通过Https访问网站的过程包括输入网址、DNS解析、建立TCP连接、发送HTTPS请求、接收响应、验证证书和解析网页内容等步骤,确保用户与服务器之间的安全通信。
238 3
|
3月前
|
缓存 网络协议 算法
从零开始掌握HTTP协议
本文介绍HTTP协议的演变,从HTTP1.0到HTTP2.0。HTTP1.0为无状态连接,每次请求独立;HTTP1.1引入持久连接、管道化请求和更多状态码;HTTP2.0采用二进制分帧、多路复用、头部压缩及服务器主动推送,大幅提升性能与用户体验。了解这些区别有助于开发者优化应用和服务。