会话技术Cookie案例
会话技术Cookie案例
记住上一次访问时间
1.访问一个servlet,如果是第一次访问,则提示∶您好,欢迎您首次访问。
2.如果不是第一次访问,则提示∶欢迎回来,您上次访问时间为:显示时间字符串
分析:
1.可以采用Cookie来完成
2.在服务器中的Servlet判断是否有一个名为lastTime的cookie
1.有:不是第一次访问
>响应数据:欢迎回来,您上次访问时间为:2022年8月11日13:27:27
>写回Cookie:lastTime=2022年8月11日13:27:50
2.没有:是第一次访问
>响应数据:您好,欢迎您首次访问
>写回Cookie:lastTime=2022年8月11日13:28:43
图解析:

代码实现:
@WebServlet("/cookieD6")
public class CookieD6 extends HttpServlet {
@Override
protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
//设置响应的消息体的数据格式以及编码
resp.setContentType("text/html;charset=utf-8");
//获取所有的Cookie
Cookie[] cookies = req.getCookies();
boolean flag = false;//代表没有cookie为lastTime
//遍历Cookies数组
if (cookies!=null && cookies.length>0){
for (Cookie cookie : cookies) {
//获取cookie的名称
String name = cookie.getName();
//判断名称是否是:lastTime
if ("lastTime".equals(name)){
//有该cookie,不是第一次访问
flag = true;//有lastTime的cookie
//响应数据
//获取Cookie的value,时间
String value = cookie.getValue();
System.out.println("解码前:"+value);
//URL解码
value = URLDecoder.decode(value,"utf-8");
System.out.println("解码后:"+value);
resp.getWriter().write("欢迎回来,你上一次访问的时间为:"+value);
//设置Cookie的value
//获取当前时间的字符串,重新设置Cookie的值,重新发送Cookie
Date date = new Date();
SimpleDateFormat sdf = new SimpleDateFormat("yyyy年MM月dd日 HH:mm:ss");
String str_date = sdf.format(date);
System.out.println("编码前:"+str_date);
//URL编码
str_date = URLEncoder.encode(str_date,"utf-8");
System.out.println("编码后:"+str_date);
cookie.setValue(str_date);
//设置Cookie的存活时间
cookie.setMaxAge(60*60*24);//60*60*24一天.一个月为:60*60*24*30
resp.addCookie(cookie);
break;
}
}
}
if (cookies == null || cookies.length==0 || flag==false){
//没有第一次访问
Date date = new Date();
SimpleDateFormat sdf = new SimpleDateFormat("yyyy年MM月dd日 HH:mm:ss");
String str_date = sdf.format(date);
System.out.println("编码前:"+str_date);
//URL编码
str_date = URLEncoder.encode(str_date,"utf-8");
System.out.println("编码后:"+str_date);
Cookie cookie = new Cookie("lastTime",str_date);
//设置Cookie的存活时间
cookie.setMaxAge(60*60*24);//60*60*24一天.一个月为:60*60*24*30
resp.addCookie(cookie);
resp.getWriter().write("您好,欢迎您首次访问");
}
}
@Override
protected void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
this.doGet(req, resp);
}
}




浙公网安备 33010602011771号