這裡是cookie的簡單應用 告訴用戶您的上次訪問時間是:xxxx-xx-xx xx:xx:xx 思路: 第一次訪問該網站時候,記錄當前訪問時間(new Date()) 把當前時間以cookie的形式寫給客戶端(response.addCookie) 第二次訪問時候,獲取客戶端攜帶的相應的cooki ...
這裡是cookie的簡單應用
告訴用戶您的上次訪問時間是:xxxx-xx-xx xx:xx:xx
思路:
第一次訪問該網站時候,記錄當前訪問時間(new Date())
把當前時間以cookie的形式寫給客戶端(response.addCookie)
第二次訪問時候,獲取客戶端攜帶的相應的cookie,並且顯示給用戶
覆蓋上次訪問時間
代碼實現:
package cookie; import java.io.IOException; import java.text.SimpleDateFormat; import java.util.Date; import javax.servlet.ServletException; import javax.servlet.http.Cookie; import javax.servlet.http.HttpServlet; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; public class LastAccessTimeServlet extends HttpServlet { public void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { // 獲得當前時間,並格式化 Date date = new Date(); SimpleDateFormat format = new SimpleDateFormat("yyyy-MM-dd hh:mm:ss"); String currentTime = format.format(date); // 創建cookie,記錄最新訪問時間 Cookie cookie = new Cookie("lastAccessTime", currentTime); // cookie保存時間24小時 cookie.setMaxAge(60 * 60 * 24); // 保存cookie response.addCookie(cookie); // 獲得客戶端攜帶的cookie String lastAccessTime = null; Cookie[] cookies = request.getCookies(); if(cookies!=null){ for(Cookie coo : cookies){ if("lastAccessTime".equals(coo.getName())){ lastAccessTime = coo.getValue(); } } } response.setContentType("text/html;charset=UTF-8"); if(lastAccessTime==null){ response.getWriter().write("您是第一次訪問"); }else{ response.getWriter().write("您上次的訪問的時間是:"+lastAccessTime); } } public void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { doGet(request, response); } }
註意web.xml配置
效果:
第一次訪問:
第二次訪問(刷新):
完成