response响应对象

response响应对象

1.提供的方法

void addCookie(Cookie cookie);

​ 服务端向客户端增加cookie对象

void sendRedirect(String location) throw IOException;

​ 页面跳转的一种方式(重定向)

void setContetType(String type);

​ 设置服务端响应的编码(contentType类型)

2.示例:登陆页面校验

login.jsp

<%@ page contentType="text/html;charset=UTF-8" language="java" %>


    Title


        
用户名:
密码:

check.jsp

<%@ page contentType="text/html;charset=UTF-8" language="java" %>


    Title


        <%
            request.setCharacterEncoding("utf-8");//设置编码
            String name=request.getParameter("username");
            String pwd=request.getParameter("userpwd");
            if(name.equals("zs")&&pwd.equals("abc")){
               // 会导致数据丢失
                // response.sendRedirect("success.jsp");
                // 换成请求转发
                request.getRequestDispatcher("success.jsp").forward(request,response);
                //页面跳转:请求转发,可以获取到数据,地址栏没有改变(仍然保留转发时的地址栏)
            }
            else {
                out.print("账号密码错误");
            }
        %>


success.jsp

<%@ page contentType="text/html;charset=UTF-8" language="java" %>


    Title


登录成功!
欢迎您 <% String name=request.getParameter("username"); out.print(name); %>

3.请求转发和重定向的区别

请求转发:getRequestDispatcher("success.jsp").forward(request,response);

重定向:response.sendRedirect("success.jsp");

请求转发 重定向

​ 地址栏是否改变 不改变 改变

​ 是否保留第一次请求时的数据 保留 不保留

​ 请求的次数 1次 2次

​ 跳转发生的位置 服务端 客户端

请求转发:

在服务器内部跳转,可以携带数据

response响应对象_第1张图片

重定向

返回给客户端让客户端重新发起跳转,不携带数据

原因:重定向两次请求,而request请求的作用域在当前一次请求有效,第二次请求不会有第一次请求的参数,所以数据丢失

response响应对象_第2张图片

例:

​ 张三去银行办理业务:

请求转发:

​ 张三(客户端) ------> 【服务窗口A(服务端)------>服务窗口B】 (【】内视为一个服务端)

​ 在这里张三只找了A,只有一次请求,A自己去找B将事情解决,所以地址栏不变

重定向:

​ 张三(客户端) ------> 服务窗口A(服务端)------>去找服务窗口B

​ 张三(客户端) ------> 服务窗口B(服务端)

​ 在这里张三找了两个人,有两次请求,所以地址栏会改变

4.session和Cookie

session(服务端)、Cookie(客户端,不是内置对象):Cookie是客户端对象,却是由服务端产生,再发送给客户端保存

Cookie是本地缓存。

​ 本地缓存的作用:可以提高访问效率,但是安全性较差,因为还可以保存密码

​ 例如在网上看电影:客户端 —>服务端(hello.mp4)

​ 第一次客户端向服务端请求hello.mp4观看。服务端将电影放进Cookie里发送给客户端。下次 观看只需从本机观看。

Cookie:name =value

Cookie来自java.servlet.http.Cookie

public Cookie(String name,String value)

String getName() //获取name

String getValue() //获取value

void setMaxage(int expiry) //设置最大有效期(秒)

服务端发送Cookie给客户端:

步骤:

服务端准备Cookie:

response.addCookie(Cookie cookie);

页面跳转(转发,重定向);

客户端获取:

cookie:request.getCookies(); //获取cookie必须全部获取,不可以获取其中一个

你可能感兴趣的:(jsp学习笔记-,response响应对象)