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" %>
<html>
<head>
<title>Title</title>
</head>
<body>
<form action="check.jsp"method="post">
用户名:<input type="text" name="username"><br/>
密码:<input type="password" name="userpwd"><br/>
<input type="submit" value="登录">
</form>
</body>
</html>
check.jsp
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head>
<title>Title</title>
</head>
<body>
<%
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("账号密码错误");
}
%>
</body>
</html>
success.jsp
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head>
<title>Title</title>
</head>
<body>
登录成功!</br>
欢迎您
<%
String name=request.getParameter("username");
out.print(name);
%>
</body>
</html>
3.请求转发和重定向的区别
请求转发:getRequestDispatcher("success.jsp").forward(request,response);
重定向:response.sendRedirect("success.jsp");
请求转发 重定向
地址栏是否改变 不改变 改变
是否保留第一次请求时的数据 保留 不保留
请求的次数 1次 2次
跳转发生的位置 服务端 客户端
请求转发:
在服务器内部跳转,可以携带数据
重定向
返回给客户端让客户端重新发起跳转,不携带数据
原因:重定向两次请求,而request请求的作用域在当前一次请求有效,第二次请求不会有第一次请求的参数,所以数据丢失
例:
张三去银行办理业务:
请求转发:
张三(客户端) ------> 【服务窗口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必须全部获取,不可以获取其中一个