package com.javaweb.servlet;
/*案例:网站为了提高用户的感受,将用户的上一次的访问时间
* 显示给用户使用cookie来实现
* 浏览器关闭之后再次打开去访问,发现又变成第一次访问了
* 注意:默认情况下。一个cookie的有效期是浏览器进程,那么在浏览器关闭之后浏览器进程就没有了
* 那么相应的cookie信息也就没有了,如何实现在浏览器关闭之后,再次打开仍然可以显示上次
* 访问时间呢?
* 可以自己手动的去设置cookie的有效期就好了,设置cookie的有效期之后,只要是有效期内
* ,那么cookie就会一直保留在浏览器的缓存中,以文件的形式存在。
* 第二:给cookie设置有效路径,那么就表示当再次使用浏览器去访问某个目标资源的时候,如果要
* 访问的目标的路径与cookie所包含的有效路径不匹配,那么cookie不会在访问的时候带给服务器,
* 1:一般情况下设置成什么样的路径较多?
* setPath(“/”)写成/并不是最好的但是确实使用最多的
* 2:一个cookie持久化保存到硬盘上的时候实际上还是可以通知浏览器删除这个cookie的,就是将
* setMaxAge设置为0,设置为0就是表示不保存cookie信息了,但是特别注意,删除cookie的时候
* 这个cookie名称和有效路径必须一致,否则不会删除。
* */
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;
/**
* Servlet implementation class ServletAfterTime
*/
@WebServlet("/servletAfterTime")
public class ServletAfterTime extends HttpServlet {
private static final long serialVersionUID = 1L;
/**
* @see HttpServlet#HttpServlet()
*/
public ServletAfterTime() {
super();
// TODO Auto-generated constructor stub
}
/**
* @see HttpServlet#doGet(HttpServletRequest request, HttpServletResponse response)
*/
protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
// TODO Auto-generated method stub
doPost(request, response);
}
/**
* @see HttpServlet#doPost(HttpServletRequest request, HttpServletResponse response)
*/
protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
// TODO Auto-generated method stub
//获取用户请求的时候封装在request中的cookie信息
Cookie[] cookies=request.getCookies();
//遍历这个cookie的数组,找到目标cookie对象,每一个cookie会有一个唯一的名字用来标识该cookie对象
Cookie tagetCookie=findeTagetCookie(cookies, "lastvisit");
response.setContentType("text/html;charset=utf-8");
if (tagetCookie==null) {
//说明没有带cookie目标过来,那么就默认为你是第一次访问
response.getWriter().print("哥们,你是第一次访问本网站。。。。");
}else {
//说明访问过
String value= tagetCookie.getValue();
long time= Long.parseLong(value);
response.getWriter().print("哥们,您上一次访问的时间是:"+new Date(time).toLocaleString());
}
//当前的时间写回去
Cookie cookie=new Cookie("lastvisit", System.currentTimeMillis()+"");
cookie.setPath("/");
//设置有效路径,/表示当前主机名localhost,表示只有访问localhost主机下的某个资源的时候才会带过去
cookie.setMaxAge(60*60*24*7);//以当前时间开始,保存一个星期;以秒为单位
response.addCookie(cookie);//将cookie写给用户的浏览器
}
private Cookie findeTagetCookie(Cookie[] cookies,String name){
if (cookies==null) {
//说明没有带任何数据的cookie过来,就直接返回null
return null;
}
//如果走到这里,则说明带了cookie过来,那么就遍历这个数组,找到目标的cookie对象
for (Cookie cookie : cookies) {
if (cookie.getName().equals(name)) {
//说明当前的cookie就是目标cookie,那么就会返回cookie对象
return cookie;
}
}
return null;
}
/*案例:网站为了提高用户的感受,将用户的上一次的访问时间
* 显示给用户使用cookie来实现
* 浏览器关闭之后再次打开去访问,发现又变成第一次访问了
* 注意:默认情况下。一个cookie的有效期是浏览器进程,那么在浏览器关闭之后浏览器进程就没有了
* 那么相应的cookie信息也就没有了,如何实现在浏览器关闭之后,再次打开仍然可以显示上次
* 访问时间呢?
* 可以自己手动的去设置cookie的有效期就好了,设置cookie的有效期之后,只要是有效期内
* ,那么cookie就会一直保留在浏览器的缓存中,以文件的形式存在。
* 第二:给cookie设置有效路径,那么就表示当再次使用浏览器去访问某个目标资源的时候,如果要
* 访问的目标的路径与cookie所包含的有效路径不匹配,那么cookie不会在访问的时候带给服务器,
* 1:一般情况下设置成什么样的路径较多?
* setPath(“/”)写成/并不是最好的但是确实使用最多的
* 2:一个cookie持久化保存到硬盘上的时候实际上还是可以通知浏览器删除这个cookie的,就是将
* setMaxAge设置为0,设置为0就是表示不保存cookie信息了,但是特别注意,删除cookie的时候
* 这个cookie名称和有效路径必须一致,否则不会删除。
* */
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;
/**
* Servlet implementation class ServletAfterTime
*/
@WebServlet("/servletAfterTime")
public class ServletAfterTime extends HttpServlet {
private static final long serialVersionUID = 1L;
/**
* @see HttpServlet#HttpServlet()
*/
public ServletAfterTime() {
super();
// TODO Auto-generated constructor stub
}
/**
* @see HttpServlet#doGet(HttpServletRequest request, HttpServletResponse response)
*/
protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
// TODO Auto-generated method stub
doPost(request, response);
}
/**
* @see HttpServlet#doPost(HttpServletRequest request, HttpServletResponse response)
*/
protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
// TODO Auto-generated method stub
//获取用户请求的时候封装在request中的cookie信息
Cookie[] cookies=request.getCookies();
//遍历这个cookie的数组,找到目标cookie对象,每一个cookie会有一个唯一的名字用来标识该cookie对象
Cookie tagetCookie=findeTagetCookie(cookies, "lastvisit");
response.setContentType("text/html;charset=utf-8");
if (tagetCookie==null) {
//说明没有带cookie目标过来,那么就默认为你是第一次访问
response.getWriter().print("哥们,你是第一次访问本网站。。。。");
}else {
//说明访问过
String value= tagetCookie.getValue();
long time= Long.parseLong(value);
response.getWriter().print("哥们,您上一次访问的时间是:"+new Date(time).toLocaleString());
}
//当前的时间写回去
Cookie cookie=new Cookie("lastvisit", System.currentTimeMillis()+"");
cookie.setPath("/");
//设置有效路径,/表示当前主机名localhost,表示只有访问localhost主机下的某个资源的时候才会带过去
cookie.setMaxAge(60*60*24*7);//以当前时间开始,保存一个星期;以秒为单位
response.addCookie(cookie);//将cookie写给用户的浏览器
}
private Cookie findeTagetCookie(Cookie[] cookies,String name){
if (cookies==null) {
//说明没有带任何数据的cookie过来,就直接返回null
return null;
}
//如果走到这里,则说明带了cookie过来,那么就遍历这个数组,找到目标的cookie对象
for (Cookie cookie : cookies) {
if (cookie.getName().equals(name)) {
//说明当前的cookie就是目标cookie,那么就会返回cookie对象
return cookie;
}
}
return null;
}
}
运行结果:
(因为浏览过一次,所以显示的是上一次的浏览时间,如果是第一次就会显示“哥们,你是第一次访问本网站。。。。”)