Servlet---请求转发和重定向、cookie

一、请求转发

服务器在接收到浏览器的请求后,仅仅使用一个Servlet 进行请求处理,会造成不同的 Servlet 逻辑代码冗余,Servlet 的职责不明确。使用请求转发可以实现一次请求,执行多个servlet。

在Servlet中调用request对象的getRequestDispatcher(location).forward(req,resp);方法

req.getRequestDispatcher(地址).forward(req,resp);
//地址为相对路径,直接书写Servlet的别名即可

特点:使用请求转发,执行多个Servlet但只用一次请求,并且浏览器地址栏信息不变(有可能造成数据的重复提交)。

在地址中/代表项目根目录,与重定向有区别。

二、Request对象的作用域

使用请求转发后,不同的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的别名中包含目录,会造成重定向资源查找失败。

绝对路径:第一个/表示服务器根目录       应为/虚拟项目名/资源路径

四、Cookie

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);
    }

 

 

 

你可能感兴趣的:(JavaWEB)