协议
两个应用之间进行信息的传输需要对传输的格式进行一些的商定,这样才能顺利地交通。这就像我们的自然语言,都会是由一定的语法构成一个句子的完整的意思,没有了我们已经知道的或是默认的语法,那么就不能顺畅地进行沟通。对于一些企业的内部应用,企业内部可以自己制定自已客户端和服务端沟通的协议。
http协议
对于web应用,http就是万维网组织为我们所有基于b/s架构的软件开发商定的标准。通过这个协议标准,能够将超文本标记语言文档从web服务器传送到客户端的浏览器,进而渲染成为美观的web页面。
http是一种基于TCP/IP的应用层协议。是无连接、无状态的。无连接表现为一次请求一次响应。无状态表现为服务端并不知道客户端浏览器以前是否请求过什么信息等等。
客户端的请求消息结构
- 请求行
- 请求头(与请求数据间有一行空行)
- 请求数据
常用的请求头
Accept:用于告诉服务器,客户机支持的数据类型 (例如:Accept:text/html,image/*表示支持网页、图片)
Accept-Charset:用于告诉服务器,客户机采用的编码格式,如utf-8、iso-8859-1等
Accept-Encoding:用于告诉服务器,客户机支持的数据压缩格式,如gzid
Accept-Language:客户机语言环境,如中文等为zh-cn
Host:客户机通过这个服务器,想访问的主机名
If-Modified-Since:客户机通过这个头告诉服务器,资源的缓存时间
Referer:客户机通过这个头告诉服务器,它(客户端)是从哪个资源来访问服务器的(防盗链)
User-Agent:客户机通过这个头告诉服务器,客户机的软件环境(操作系统,浏览器版本等)
Cookie:客户机通过这个头,将Coockie信息带给服务器
Connection:告诉服务器,请求完成后,是否保持连接
Date:告诉服务器,当前请求的时间
服务端的响应格式
- 状态行
- 响应头
- 响应体
常用的响应头
Location:这个头配合302状态吗,用于告诉客户端找谁
Server:服务器通过这个头,告诉浏览器服务器的类型,如tomcat
Content-Encoding:告诉浏览器,服务器的数据压缩格式
Content-Length:告诉浏览器,回送数据的长度
Content-Type:告诉浏览器,回送数据的类型
Last-Modified:告诉浏览器当前资源缓存时间
Refresh:告诉浏览器,隔多长时间刷新
Content-Disposition:告诉浏览器以下载的方式打开数据。
例如: context.Response.AddHeader("Content-Disposition","attachment:filename=aa.jpg"); context.Response.WriteFile("aa.jpg");
Transfer-Encoding:告诉浏览器,传送数据的编码格式
ETag:缓存相关的头(可以做到实时更新)
Expries:告诉浏览器回送的资源缓存多长时间。如果是-1或者0,表示不缓存
Cache-Control:控制浏览器不要缓存数据 no-cache
Pragma:控制浏览器不要缓存数据 no-cache
Connection:响应完成后,是否断开连接。 close/Keep-Alive
Date:告诉浏览器,服务器响应时间
http的状态码
- 1**:表示消息服务器已经收到,但是还需要请求者继续操作,如101表示需要切换协议。(是协议处理中的一种中间状态)
- 2**:成功200,
「200 OK」是最常见的成功状态码,表示一切正常。如果是非
HEAD
请求,服务器返回的响应头都会有 body 数据。「204 No Content」也是常见的成功状态码,与 200 OK 基本相同,但响应头没有 body 数据。
「206 Partial Content」是应用于 HTTP 分块下载或断电续传,表示响应返回的 body 数据并不是资源的全部,而是其中的一部分,也是服务器处理成功的状态。
- 3**:重定向,需要进一步操作,
「301 Moved Permanently」表示永久重定向,说明请求的资源已经不存在了,需改用新的 URL 再次访问。
「302 Found」表示临时重定向,说明请求的资源还在,但暂时需要用另一个 URL 来访问。
301 和 302 都会在响应头里使用字段
Location
,指明后续要跳转的 URL,浏览器会自动重定向新的 URL。「304 Not Modified」不具有跳转的含义,表示资源未修改,重定向已存在的缓冲文件,也称缓存重定向,用于缓存控制。
- 4**:客户端错误,如404找不到页面
「400 Bad Request」表示客户端请求的报文有错误,但只是个笼统的错误。
「403 Forbidden」表示服务器禁止访问资源,并不是客户端的请求出错。
「404 Not Found」表示请求的资源在服务器上不存在或未找到,所以无法提供给客户端。
- 5**:服务端错误,如500表示内部服务器错误
「500 Internal Server Error」与 400 类型,是个笼统通用的错误码,服务器发生了什么错误,我们并不知道。
「501 Not Implemented」表示客户端请求的功能还不支持,类似“即将开业,敬请期待”的意思。
「502 Bad Gateway」通常是服务器作为网关或代理时返回的错误码,表示服务器自身工作正常,访问后端服务器发生了错误。
「503 Service Unavailable」表示服务器当前很忙,暂时无法响应服务器,类似“网络服务正忙,请稍后重试”的意思。