啥是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¶m2=value2的键值对形式编码成一个格式化串,它承载多个请求参数的数据。不但报文体可以传递请求参数,请求URL也可以通过类似于“/chapter15/user.html? param1=value1¶m2=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