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;
                }
            }
        }
    }
復制代碼

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM