1、请求转发和重定向:
登陆html --> Servlet —>登陆成功html —>另一个Servlet
这里的Servlet向html转的过程有两种方式:请求转发和重定向
- 以前的写法:
response.setStatus(302);
response.setHeader("Location", "login_success.html");
- 请求转发:
request.getRequestDispatcher("login_success.html").forward(request, response);
- 地址上显示的是请求servlet的地址。 返回200 ok
- 请求次数只有一次, 因为是服务器内部帮客户端执行了后续的工作。
- 只能跳转自己项目的资源路径 。
- 效率上稍微高一点,因为只执行一次请求。
- 可以使用上一次的request对象。
- 重定向:
response.sendRedirect("login_success.html");
- 地址上显示的是最后的那个资源的路径地址
- . 请求次数最少有两次, 服务器在第一次请求后,会返回302 以及一个地址, 浏览器在根据这个地址,执行第二次访问。
- 可以跳转到任意路径。 不是自己的工程也可以跳。
- 效率稍微低一点, 执行两次请求。
- 后续的请求,没法使用上一次的request存储的数据,或者 没法使用上一次的request对象,因为这是两次不同的请求。
2、Cookie及其应用:
在 Internet 中,Cookie 实际上是指小量信息,是由 Web 服务器创建的,将信息存储在用户计算机上的文件。一般网络用户习惯用其复数形式 Cookies,指某些网站为了辨别用户身份、进行 Session 跟踪而存储在用户本地终端上的数据,而这些数据通常会经过加密处理。 ----百度百科
为什么要有cookie(面试)?
http的请求是无状态。 客户端与服务器在通讯的时候,是无状态的,其实就是客户端在第二次来访的时候,服务器根本就不知道这个客户端以前有没有来访问过。 为了更好的用户体验,更好的交互 [自动登录],其实从公司层面讲,就是为了更好的收集用户习惯[大数据]
- Cookie应用一:显示最近访问的时间:
实现效果如图:
思路如下:
代码如下:
登陆页面:index.html
<body>
<form action="CookieT">
姓名:<input type="text" name="name"><br>
密码:<input type="password" name="password"><br>
<input type="submit" >
</form>
</body>
CookieT的Servlet:
package cn.nupt;
import java.io.IOException;
import java.util.Date;
import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.Cookie;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import CookUtilPack.CookieUtil;
/**
* Servlet implementation class CookieT
*/
@WebServlet("/CookieT")
public class CookieT extends HttpServlet {
private static final long serialVersionUID = 1L;
protected void doGet(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
// 1.拿到數據
response.setContentType("text/html;charset=UTF-8");
String name = request.getParameter("name");
String pass = request.getParameter("password");
if ("admin".equals(name) && "123".equals(pass)) {
response.getWriter().write("登陸成功");
Cookie[] cookies = request.getCookies();
Cookie cookie = CookieUtil.findCookie(cookies, "lastTime");
if (cookie == null) {
// 第一次登陆,没有cookie
Cookie cookie2 = new Cookie("lastTime", System.currentTimeMillis() + ""); // 1、获得当前系统时间
// 2、long变为String类型
cookie2.setMaxAge(60 * 60);// 设置cookie的缓存时间
response.addCookie(cookie2);
} else {
// 第二次登陆,已经有cookie了
long lastVistTime = Long.parseLong(cookie.getValue());
response.getWriter().write("您上次登陆的时间为:" + new Date(lastVistTime));
cookie.setValue(System.currentTimeMillis() + "");
response.addCookie(cookie);
}
} else {
response.getWriter().write("登陸失敗");
}
}
protected void doPost(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
doGet(request, response);
}
}