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