Cookie经典案例—实现显示用户上次服务时间的显示
本篇博客讓我們來了解JavaWeb中的會話和會話技術,了解什么是Cookie,掌握Cookie對象的使用.
1.什么是會話?
1.會話:一次會話中包含多次請求和響應.
一次會話:瀏覽器第一次給服務器資源發送請求,會話建立,直到有一方斷開為止.
2.會話的功能:在一次會話中,實現數據共享.
3.會話的方式:
1.客戶端會話技術:Cookie
2.服務器端會話技術:Session
2.Cookie:
1.概念:客戶端會話技術,將數據保存到客戶端
2.常用方法:
| 創建Cookie對象,綁定數據 | new Cookie(String name,String value) |
| 發送Cookie對象 | resp.addCookie(Cookie cookie) |
| 獲取Cookie,拿到數據 | Cookie[] req.getCookies() |
3.實現原理:
? ? ? ? ? ? ? ? ? ? ? ?基于響應頭set-cookie和請求頭cookie實現
4.注意事項:
1.一次可以發送多個cookie.可以創建多個cookie對象,使用response調用多次addCookie方法發送cookie即可.
2.cookie在瀏覽器中保存的保存時間.使用setMaxAge(int seconds)方法可以將cookie數據寫到文件中,并且指定cookie的存活時間.?
3.cookie存儲數據在客戶端瀏覽器中.
3.Cookie在瀏覽器和服務器之間的傳輸過程:
當用戶第一次訪問服務器時,服務器會在響應消息中增加Set-Cookie頭字段,將用戶信息以Cookie的形式發送給瀏覽器.用戶瀏覽器一旦接收到服務器發送的Cookie信息,就會將它保存到自身緩沖區中.這樣,當瀏覽器后繼續訪問服務器時,都會在請求消息中將用戶信息以Cookie的形式發送給服務器,從而使服務器分辨當前請求是那個用戶發出的.?
4.實現顯示用戶上次服務時間的顯示
【任務目標】
當用戶訪問某些Web應用時,經常會顯示該用戶上次的訪問時間。
【代碼實現】
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; import java.io.IOException; import java.text.SimpleDateFormat; import java.util.Date;/*** @author Sun* @version 2021.2* @date 2022/5/5 17:28*/ @WebServlet("/LastAssessTime") public class LastAssessServlet extends HttpServlet {@Overrideprotected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {//指定服務器輸出內容編碼方式,以防發生亂碼resp.setContentType("text/html;charset=utf-8");//獲取所有的cookieCookie[] cookies=req.getCookies();//定義flag 用于判斷cookies是否為空boolean flag=false;//遍歷cookie數組if (cookies!=null && cookies.length>0){for (Cookie cookie:cookies) {//獲取cookie的名稱String name=cookie.getName();//判斷名稱是否為LastAssessTimeif ("LastAssessTime".equals(name)){//該cookie不是第一次訪問flag=true;//響應數據//獲取cookie中的value時間String value=cookie.getValue();resp.getWriter().write("上次訪問時間"+value);//設置cookie的value//獲取當前時間的字符串,重新設置cookie的值,重新發送cookieDate date=new Date();SimpleDateFormat sdf=new SimpleDateFormat("yyyy-MM-dd-hh:mm:ss");String time= sdf.format(date);cookie.setValue(time);//設置cookie存活時間cookie.setMaxAge(60*60*24*5);//5天//加入當前cookie請求時間resp.addCookie(cookie);break;}}}if (cookies==null || cookies.length==0 || flag==false){//設置cookie的valueDate date=new Date();SimpleDateFormat sdf=new SimpleDateFormat("yyyy-MM-dd-hh:mm:ss");String time= sdf.format(date);Cookie cookie=new Cookie("LastAssessTime",time);//設置cookie存活時間cookie.setMaxAge(60*60*24*5);//5天//加入當前cookie請求時間resp.addCookie(cookie);resp.getWriter().write("歡迎首次訪問");}}@Overrideprotected void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {this.doPost(req,resp);} }?運行結果:
第一次訪問:
?第二次訪問:
?關閉瀏覽器后重新訪問:
?因為當前Cookie的存活時間為五天,
所以關閉瀏覽器,重新打開依舊顯示時間。
但在默認情況下,Cookie對象的maxAge屬性值為-1,即關閉瀏覽器時刪除當前Cookie對象,這樣的話重啟瀏覽器訪問則會顯示:歡迎首次訪問。
如果覺得對你有幫助,就給小孫留下一個點贊+收藏吧?
總結
以上是生活随笔為你收集整理的Cookie经典案例—实现显示用户上次服务时间的显示的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 2021年三季度中国通用设备行业A股上市
- 下一篇: SG Input 软件安全分析之逆向分析