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 表示字节数。

相关文章
|
8天前
|
网络协议 安全 Go
Go语言进行网络编程可以通过**使用TCP/IP协议栈、并发模型、HTTP协议等**方式
【10月更文挑战第28天】Go语言进行网络编程可以通过**使用TCP/IP协议栈、并发模型、HTTP协议等**方式
34 13
|
5天前
|
开发者
HTTP 协议请求方法的发展历程
【10月更文挑战第21天】
|
5天前
|
安全
HTTP 协议的请求方法
【10月更文挑战第21天】
|
5天前
|
缓存 安全 前端开发
HTTP 协议的请求方法在实际应用中有哪些注意事项?
【10月更文挑战第29天】HTTP协议的请求方法在实际应用中需要根据具体的业务场景和需求,合理选择和使用,并注意各种方法的特点和限制,以确保网络通信的安全、高效和数据的一致性。
|
7天前
|
存储 缓存 网络协议
计算机网络常见面试题(二):浏览器中输入URL返回页面过程、HTTP协议特点,GET、POST的区别,Cookie与Session
计算机网络常见面试题(二):浏览器中输入URL返回页面过程、HTTP协议特点、状态码、报文格式,GET、POST的区别,DNS的解析过程、数字证书、Cookie与Session,对称加密和非对称加密
|
9天前
|
网络协议 前端开发 API
HTTP 和 TCP 协议的应用场景有哪些不同
【10月更文挑战第25天】HTTP(超文本传输协议)和 TCP(传输控制协议)处于网络协议栈的不同层次,各自具有独特的功能和特点,因此它们的应用场景也存在明显的差异。
|
9天前
|
安全 前端开发 JavaScript
利用HTTP协议进行文件上传和下载的常见方法
【10月更文挑战第25天】可以利用HTTP协议方便地实现文件的上传和下载功能,满足不同应用场景下的需求。在实际应用中,还可以根据具体的业务需求和安全要求,对文件上传和下载的过程进行进一步的优化和安全处理。
|
9天前
|
网络协议 API 数据格式
HTTP 和 TCP 协议的主要区别
【10月更文挑战第25天】HTTP 和 TCP 在网络通信中扮演着不同的角色,各自具有独特的功能和特点,它们相互配合,共同为实现网络应用的各种需求提供了基础支持。
|
18天前
|
网络协议 物联网 网络性能优化
物联网协议比较 MQTT CoAP RESTful/HTTP XMPP
【10月更文挑战第18天】本文介绍了物联网领域中四种主要的通信协议:MQTT、CoAP、RESTful/HTTP和XMPP,分别从其特点、应用场景及优缺点进行了详细对比,并提供了简单的示例代码。适合开发者根据具体需求选择合适的协议。
43 5
|
1月前
|
缓存 网络协议 前端开发
Web 性能优化|了解 HTTP 协议后才能理解的预加载
本文旨在探讨和分享多种预加载技术及其在提升网站性能、优化用户体验方面的应用。
下一篇
无影云桌面