javaWeb(六)请求转发和重定向、Cookie及其应用(显示最近访问的时间)

1、请求转发和重定向:

登陆html --> Servlet —>登陆成功html —>另一个Servlet

这里的Servlet向html转的过程有两种方式:请求转发和重定向

javaWeb(六)请求转发和重定向、Cookie及其应用(显示最近访问的时间)_第1张图片

  • 以前的写法:
response.setStatus(302);
response.setHeader("Location", "login_success.html");
  • 请求转发:
request.getRequestDispatcher("login_success.html").forward(request, response);
  1. 地址上显示的是请求servlet的地址。 返回200 ok
  2. 请求次数只有一次, 因为是服务器内部帮客户端执行了后续的工作。
  3. 只能跳转自己项目的资源路径 。
  4. 效率上稍微高一点,因为只执行一次请求。
  5. 可以使用上一次的request对象。
  • 重定向:
 response.sendRedirect("login_success.html");
  1. 地址上显示的是最后的那个资源的路径地址
  2. . 请求次数最少有两次, 服务器在第一次请求后,会返回302 以及一个地址, 浏览器在根据这个地址,执行第二次访问。
  3. 可以跳转到任意路径。 不是自己的工程也可以跳。
  4. 效率稍微低一点, 执行两次请求。
  5. 后续的请求,没法使用上一次的request存储的数据,或者 没法使用上一次的request对象,因为这是两次不同的请求。

2、Cookie及其应用:

在 Internet 中,Cookie 实际上是指小量信息,是由 Web 服务器创建的,将信息存储在用户计算机上的文件。一般网络用户习惯用其复数形式 Cookies,指某些网站为了辨别用户身份、进行 Session 跟踪而存储在用户本地终端上的数据,而这些数据通常会经过加密处理。 ----百度百科

为什么要有cookie(面试)?

http的请求是无状态。 客户端与服务器在通讯的时候,是无状态的,其实就是客户端在第二次来访的时候,服务器根本就不知道这个客户端以前有没有来访问过。 为了更好的用户体验,更好的交互 [自动登录],其实从公司层面讲,就是为了更好的收集用户习惯[大数据]

  • Cookie应用一:显示最近访问的时间:

实现效果如图:
在这里插入图片描述

思路如下:

javaWeb(六)请求转发和重定向、Cookie及其应用(显示最近访问的时间)_第2张图片

代码如下:

登陆页面: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);
	}

}

你可能感兴趣的:(JavaWeb,javaWeb,JavaWeb)