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