http的那些事儿

199 阅读5分钟

啥是http

http协议,又称超文本传输协议,用于从万维网服务器传输超文本到本地浏览器的传送协议。基于TCP/IP通信协议,基于客户端/服务端(C/S)架构模型,是一个无状态的请求/响应协议。

特点是啥

1、无连接的:限制每次连接只处理一个请求,服务器处理完客户的请求,并收到客户的应答后,即断开连接

2、无状态的:协议对于事务处理没有记忆能力。缺少状态意味着如果后续处理需要前面的信息,则它必须重传,这样可能导致每次连接传送的数据量增大。另一方面,在服务器不需要先前信息时它的应答就较快。

3、媒体独立的:只要客户端和服务器知道如何处理的数据内容,任何类型的数据都可以通过HTTP发送。客户端以及服务器指定使用适合的MIME-type内容类型。

请求报文

HTTP请求报文由3部分组成(请求行+请求头+请求体)

请求行:

①是请求方法,GET和POST是最常见的HTTP方法,除此以外还包括DELETE、HEAD、OPTIONS、PUT、TRACE。

②为请求对应的URL地址,它和报文头的Host属性组成完整的请求URL。

③是协议名称及版本号。

请求头:

④是HTTP的报文头,报文头包含若干个属性,格式为“属性名:属性值”,服务端据此获取客户端的信息。

与缓存相关的规则信息,均包含在header中

请求体:

⑤是报文体,它将一个页面表单中的组件值通过param1=value1&param2=value2的键值对形式编码成一个格式化串,它承载多个请求参数的数据。不但报文体可以传递请求参数,请求URL也可以通过类似于“/chapter15/user.html? param1=value1&param2=value2”的方式传递请求参数。

重点来了!!!!----HTTP请求报文头属性

Accept

作用是:告诉服务端,客户端接受什么类型的响应

例如:客户端能够接受的响应类型仅为纯文本数据
Accept:text/plain 

cookie

客户端的Cookie是通过这个报文头属性传给服务端的

例如:
Cookie: $Version=1; Skin=new;jsessionid=5F4771183629C9834F8382E23 

问:服务端是怎么知道客户端的多个请求是隶属于一个Session呢?

通过HTTP请求报文头的Cookie属性的jsessionid的值关联起来的!(当然也可以通过重写URL的方式将会话ID附带在每个URL的后面哦)

Referer

表示这个请求是从哪个URL过来的。

Cache-Control

对缓存进行控制,如一个请求希望响应返回的内容在客户端要被缓存一年,或不希望被缓存就可以通过这个报文头达到目的。

响应报文

HTTP的响应报文由三部分组成(响应行+响应头+响应体)

响应行:

①报文协议及版本; ②状态码及状态描述;

响应头:

③响应报文头,也是由多个属性组成;

响应体:

④响应报文体

常用状态码

200 (OK):处理成功! 找到了该资源,并且一切正常。

302/307:临时重定向,指出请求的文档已被临时移动到别处, 此文档的新的url在location响应头中给出

304 (NOT MODIFIED): 该资源在上次请求之后没有任何修改。这通常用于浏览器的缓存机制。

401 (UNAUTHORIZED): 客户端无权访问该资源。这通常会使得浏览器要求用户输入用户名和密码,以登录到服务器。

403 (FORBIDDEN): 客户端未能获得授权。这通常是在401之后输入了不正确的用户名或密码。

404 (NOT FOUND): 即找不到页面。在指定的位置不存在所申请的资源。

500 :后台错误,此时应该查查服务端的日志了,肯定抛出了一堆异常。

响应报文头

1、Cache-Control

客户端如何控制响应内容的缓存。

常见的取值有private、public、no-cache、max-age,no-store,默认为private。 private:客户端可以缓存

public:客户端和代理服务器都可缓存(前端的同学,可以认为public和private是一样的)

max-age=xxx:缓存的内容将在 xxx 秒后失效

no-cache:需要使用对比缓存来验证缓存数据

no-store:所有内容都不会缓存

ETag

一个代表响应服务端资源(如页面)版本的报文头属性,如果某个服务端资源发生变化了,这个ETag就会相应发生变化。它是Cache-Control的有益补充,可以让客户端“更智能”地处理什么时候要从服务端取资源,什么时候可以直接从缓存中返回响应

Location

我们在JSP中让页面Redirect到一个某个A页面中,其实是让客户端再发一个请求到A页面,这个需要Redirect到的A页面的URL,其实就是通过响应报文头的Location属性告知客户端的,如下的报文头属性,将使客户端redirect到iteye的首页中:

Location: http://www.iteye.com  

Set-Cookie

服务端可以设置客户端的Cookie:

Set-Cookie: UserID=JohnDoe; Max-Age=3600; Version=1