HTTP
HTTP协议
客户端和服务器之间通信时,发送的数据,需要遵守的规则,叫HTTP协议
Http协议中的数据又称为报文
Http称之为 超文本传输协议
Http是无状态的
Http请求响应包含两部分:请求和响应
请求:
包含三个部分: 1.请求行 2.请求消息头 3.请求主体
请求行包含三个信息:1.请求方式 2. 请求的URL 3.请求的协议(一般是HTTP1.1)
请求消息头中包含了很多客户端需要告诉服务器的信息,比如:我的浏览器型号、版本、我能接收的内容类型、我给你发的内容的类型,内容长度等等
请求体,三种情况
get方式,没有请求主体,但有一个queryString
post方式,请求主体,form data
json方式,请求主体,request payload
响应:
响应也包含三个部分: 1. 响应行 ;2.响应头 ;3.响应体
(1)响应行包含三个信息:1.协议 2.响应状态码(200) 3.响应状态(ok)
(2)响应头:包含了服务器的信息;服务器发送给浏览器的信息(内容的媒体类型,编码,内容长度等)
(3)响应体:响应的实际内容(比如请求add.html页面时,响应的内容就是<html><head><body><form>...
相关状态码
200 : 正常响应
404 : 找不到资源
405 : 请求方式不支持
500 : 服务器内部错误
会话
Http是无状态的
HTTP 无状态:服务器无法判断这两次请求是同一个客户端发过来的,还是不同的客户端发过来的
无状态带来的现实问题:第一次请求是添加商品到购物车,第二次请求是结账,如果这两次请求服务器无法区分是同一个用户,会导致混乱
通过会话跟踪技术来解决无状态问题
会话跟踪技术
客户端第一次发请求给服务器,服务器获取session,获取不到,则创建新的,然后响应给客户端
下一次客户端给服务器发请求时,会把 sessionID 带给服务器,那么服务器就能获取到,那么服务器就判断这一次请求和上次某个请求是同一个客户端,从而能够区分开
常用的API:
req.getSession()->获取当前的会话,没有就创建新的
req.getSession(true)->效果和不带参数的相同
req.getSession(false)->获取当前的会话,没有就返回null,不会创建新的
session.getId()->获取sessionID
session.isNew()->判断当前session是否是新的
session.getMaxInactiveInterval()->session的非激活间隔时长,默认是1800s
session.setMaxInactiveInterval();
session.invalidate();->强制性让会话失效
session保存作用域
session保存作用域是和具体的某一个session对应的
常用API:
void session.setAttribute(k,v) Object session.getAttribute(k) void removeAttribute(k)
服务器内部转发以及客户端重定向
服务器内部转发:request.getRequestDispatcher("...").forward(request,response)
一次请求响应的过程,对于客户端而言,内部经历多少次转发,客户端是不知道的
地址栏没有变化
客户端重定向:request.sendRedirect("...");
两次请求响应的过程,客户端肯定知道
地址栏有变化