1. 程式人生 > >springMVC操作cookie和session

springMVC操作cookie和session

cookie相關說明:

1、cookie由伺服器端建立,然後新增到HttpServletResponse中傳送給客戶端(瀏覽器)。

2、可以新增多個cookie鍵值對。

3、cookie由鍵值名和鍵值組成。“相同domain和path”中的鍵值名不能重複,新增鍵值名重名的鍵值對會覆蓋上一個同名的鍵值對。

4、新增cookie時要指定cookie所在域(setPath),指定存在時長(setMaxAge)。

4、服務端建立好cookie後提交給客戶端,之後瀏覽器的每次請求(HttpServletRequest)裡都會攜帶“cookie陣列”。

5、springmvc有兩種方式獲取:(1)在控制器中通過註解@CookieValue(鍵值名),獲取指定某個cookie。(2)通過HttpServletRequest中的getcookies方法獲取cookie陣列,然後迭代裡面的每一個cookie鍵值對。

session相關說明:

1、伺服器會根據客戶端的請求(HttpServletRequest)建立session(request.getSession())。

2、每一個session都有一個唯一的標示“sessionID”,可通過.getId()獲得。

3、session是儲存在伺服器端的,每一個session都有一個id,當建立一個session後,會將該sessionID存放到此次訪問的cookie中,當下次客戶端的訪問到來需要提取伺服器中的session時,會根據訪問中cookie裡的sessionID值來找到伺服器中的具體session。

4、伺服器會把長時間沒有活動的Session從伺服器記憶體中清除,此時Session便失效。Tomcat中Session的預設失效時間為20分鐘。

5、訪問html等靜態資源時不會建立session

相關操作程式碼:

複製程式碼
    //讀取cookie陣列,之後迭代出各個cookie
    public void showCookies(HttpServletRequest request){
        Cookie[] cookies = request.getCookies();//根據請求資料,找到cookie陣列

        if (null==cookies) {//如果沒有cookie陣列
            System.out.println("沒有cookie");
        } else {
            
for(Cookie cookie : cookies){ System.out.println("cookieName:"+cookie.getName()+",cookieValue:"+ cookie.getValue()); } } } //建立cookie,並將新cookie新增到“響應物件”response中。 public void addCookie(HttpServletResponse response){ Cookie cookie = new Cookie("name_test","value_test");//建立新cookie cookie.setMaxAge(5 * 60);// 設定存在時間為5分鐘 cookie.setPath("/");//設定作用域 response.addCookie(cookie);//將cookie新增到response的cookie陣列中返回給客戶端 } //修改cookie,可以根據某個cookie的name修改它(不只是name要與被修改cookie一致,path、domain必須也要與被修改cookie一致) public void editCookie(HttpServletRequest request,HttpServletResponse response){ Cookie[] cookies = request.getCookies(); if (null==cookies) { System.out.println("沒有cookies"); } else { for(Cookie cookie : cookies){ //迭代時如果發現與指定cookieName相同的cookie,就修改相關資料 if(cookie.getName().equals("name_test")){ cookie.setValue("new_value");//修改value cookie.setPath("/"); cookie.setMaxAge(10 * 60);// 修改存活時間 response.addCookie(cookie);//將修改過的cookie存入response,替換掉舊的同名cookie break; } } } } //刪除cookie public void delCookie(HttpServletRequest request,HttpServletResponse response){ Cookie[] cookies = request.getCookies(); if (null==cookies) { System.out.println("沒有cookie"); } else { for(Cookie cookie : cookies){ //如果找到同名cookie,就將value設定為null,將存活時間設定為0,再替換掉原cookie,這樣就相當於刪除了。 if(cookie.getName().equals("name_test")){ cookie.setValue(null); cookie.setMaxAge(0); cookie.setPath("/"); response.addCookie(cookie); break; } } } }
複製程式碼

 ===================================================================================================================================

轉載自:https://www.cnblogs.com/red-code/p/6629363.html

原作者是: