Cookie Cookie 是一種伺服器發送給瀏覽器以鍵值對形式存儲小量信息的技術。 當瀏覽器首次請求伺服器時,伺服器會將一條信息封裝成一個Cookie發送給瀏覽器,瀏覽器收到Cookie,會將它保存在記憶體中(註意這裡的記憶體是本機記憶體,而不是伺服器記憶體)或者本地文件,那之後每次向伺服器發送請求,瀏覽 ...
Cookie
當瀏覽器首次請求伺服器時,伺服器會將一條信息封裝成一個Cookie發送給瀏覽器,瀏覽器收到Cookie,會將它保存在記憶體中(註意這裡的記憶體是本機記憶體,而不是伺服器記憶體)或者本地文件,那之後每次向伺服器發送請求,瀏覽器都會攜帶該Cookie,伺服器就可以根據Cookie的信息來處理業務。
-
Cookie因為請求或響應是以報文發送,無形中增加了網路流量。
-
Cookie是明文傳送的安全性差。
-
Cookie的創建
-
在Servlet中創建Cookie對象,並添加到Response中。
-
然後打開瀏覽器訪問Servlet程式,伺服器將Cookie信息發送給瀏覽器。
-
瀏覽器收到Cookie後會自動保存,然後我們可以在下次瀏覽器發送請求時讀取Cookie信息。
Cookie cookie = new Cookie("cookie-name", "cookie-Value"); response.addCookie(cookie);
讀取Cookie主要指讀取瀏覽器中攜帶的Cookie。
-
伺服器端獲取瀏覽器傳過來的Cookie代碼:request.getCookies()
-
遍歷Cookie數組,獲取所有Cookie信息
// 創建一個已存在key的Cookie對象 Cookie cookie = new Cookie("cookie-name", null); // 修改Cookie的值 cookie.setValue("this is new value"); // 通知瀏覽器保存修改,記得再次add response.addCookie(cookie);
-
參數設置為0,即:setMaxAge(0):立即失效,表示瀏覽器一收到響應後,就馬上刪除Cookie
-
參數設置大於0:比如setMaxAge(60),表示有效的秒數60秒後,Cookie失效。
-
參數設置小於0:比如setMaxAge(-1),表示當前會話有效。也就是關閉瀏覽器後Cookie失效,被刪除。
-
Cookie的路徑是指告訴瀏覽器訪問哪些地址時應該攜帶該Cookie,也就是未設置的路徑不需要攜帶
-
/ :代表伺服器的根目錄
-
如果設置有效路徑為:
/day14/abc
,則:下麵幾個路徑能訪問到Cookie-
/day14/abc 能獲取Cookie
-
/day14/xxx.xxx 不能獲取Cookie
-
/day14/abc/xxx.xxx 能獲取Cookie
-
/day14/abc/a/b/c 能獲取Cookie
-
-
如果不設置,預設會在訪問“
/項目名
”下的資源時攜帶 -
Cookie cookie = new Cookie("cookie-path", "test"); // 設置Cookie的有效訪問路徑為/day14/abc/下所有資源 cookie.setPath(request.getContextPath() + "/abc"); // 通知瀏覽器保存修改 response.addCookie(cookie);
由於Cookie有一很大的局限,於是Session出現了
Session的作用就是在伺服器端保存一些用戶的數據,然後傳遞給用戶一個名字為JSESSIONID的Cookie,所以本質上它也是一個Cookie,這個JESSIONID對應這個伺服器中的一個Session對象,通過它就可以獲取到保存用戶信息的Session。
-
首先Session是jsp中九大內置對象之一
-
其次Session是一個域對象
-
然後Session是在伺服器端用來保存用戶數據的一種技術。並且Session會話技術是基於Cookie實現的。
-
-
補充:request.getSession()之後的調用都是獲取已經創建了的Session對象,單例模式
-
-
Session被創建後,同時還會有一個名為JSESSIONID的Cookie被創建。
-
-
-
當我們再次調用時會根據該JSESSIONID獲取已經存在的Cookie,而不是再創建一個新的Cookie。
-
Session的作用域是當前會話,即對應的一個瀏覽器客戶端,一個瀏覽器一個session對象非一個網頁
說明:Session對象預設的最長有效時間為30分鐘。在tomcat的conf目錄下web.xml配置文件中
設置
我們在web.xml文件中配置的Session會話超時時間是對所有Session都生效的。
setMaxInactiveInterval (int seconds) 設置用戶多長時間沒有操作之後就會Session過期。以秒為單位。
int getMaxInactiveInterval() 獲取超時時間。以秒為單位。
invalidate() 強制失效
-
-
Session活化:
如果希望Session作用域中的對象也能夠隨Session鈍化過程一起序列化到磁碟上,則對象的實現類也必須實現java.io.Serializable介面。不僅如此,如果對象中還包含其他對象的引用,則被關聯的對象也必須支持序列化,
Session對象的釋放
-
Session對象空閑時間達到了目標設置的最大值,自動釋放
-
Session對象被強制失效
-
Web應用卸載
-
伺服器進程停止
當Cookie在瀏覽器端可能會被禁用時,我們就可以使用URL重寫。
- URL重寫其實就是將JSESSIONID的值以固定格式附著在URL地址後面,以實現保持JSESSIONID,進而保持會話狀態。這個固定格式是:URL;jsessionid=xxxxxxxxx
-
response.encodeURL(String)
-
//1.獲取Session對象 HttpSession session = request.getSession(); //2.創建目標URL地址字元串 String url = "targetServlet"; //3.在目標URL地址字元串後面附加JSESSIONID的值 url = response.encodeURL(url+";jsessionid=97120112D5538009334F1C6DEADB1BE7"); //4.重定向到目標資源 response.sendRedirect(url);