服务器在接收到浏览器的请求后,仅仅使用一个Servlet 进行请求处理,会造成不同的 Servlet 逻辑代码冗余,Servlet 的职责不明确。使用请求转发可以实现一次请求,执行多个servlet。
在Servlet中调用request对象的getRequestDispatcher(location).forward(req,resp);方法
req.getRequestDispatcher(地址).forward(req,resp);
//地址为相对路径,直接书写Servlet的别名即可
特点:使用请求转发,执行多个Servlet但只用一次请求,并且浏览器地址栏信息不变(有可能造成数据的重复提交)。
在地址中/代表项目根目录,与重定向有区别。
使用请求转发后,不同的Servlet之间如何实现数据共享?或者说数据怎么从一个Servlet流转到另一个Servlet?
request对象的作用域是一整个请求,所以说可以利用request这个特点来进行不同servlet之间的数据流通
//以键值对的方式设置要流转的属性名和值
request.setAttribute(Object name,Object value);
//在另一个servlet中可以通过属性名取出
request.getAttribute(Object obj);
解决了一次请求内的不同Servlet的数据共享问题
作用域:基于请求转发,一次请求中的所有 Servlet 共享,数据只在一次请求内有效
如果使用请求转发做页面跳转,当Servlet无法处理客户端的请求或者造成表单数据重复提交的时候,应该使用重定向来解决。
response.sendRedirect(“路径”)
//本地路径为URI
//网络路径为URL
使用重定向和请求转发最大的区别就是:重定向为两次请求,而请求转发是一次请求。
相对路径:从当前请求的路径查找资源的路径,如果servlet的别名中包含目录,会造成重定向资源查找失败。
绝对路径:第一个/表示服务器根目录 应为/虚拟项目名/资源路径
HTTP 协议是没有记忆功能的,一次请求结束后,相关数据会被销毁。如果第二次的请求需要使用相同的请求数据,那就需要使用Cookie技术将数据存储到客户端本地。
Cookie技术是浏览器端的数据存储技术,适合少量数据,以键值对的形式存放,不安全。
//使用Cookie进行浏览器端的数据存储
//创建Cookie对象
Cookie c=new Cookie("mouse", "thinkpad");
Cookie c2=new Cookie("key", "bjsxt");
//设置Cookie
//设置Cookie的有效期
c2.setMaxAge(3*24*3600);
//设置有效路径
c2.setPath("/cookie/gc");
//响应Cookie信息
resp.addCookie(c);
resp.addCookie(c2);
一个Cookie对象存储一条数据。多条数据,可以多创建几个Cookie对象进行存储。
临时存储:存储在浏览器的运行内存中,浏览器关闭即失效。
定时存储:设置了Cookie的有效期,存储在客户端的硬盘中,在有效期内符合路径要求的请求都会附带该信息。
默认cookie信息存储好之后,每次请求都会附带,除非设置有效路径
//获取Cookie信息
Cookie[] cks=req.getCookies();
if(cks!=null){
for(Cookie c:cks){
String name=c.getName();
String value=c.getValue();
System.out.println(name+":"+value);
}