会话技术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); } }