亚洲av成人无遮挡网站在线观看,少妇性bbb搡bbb爽爽爽,亚洲av日韩精品久久久久久,兔费看少妇性l交大片免费,无码少妇一区二区三区

  免費(fèi)注冊 查看新帖 |

Chinaunix

  平臺 論壇 博客 文庫
最近訪問板塊 發(fā)新帖
查看: 1420 | 回復(fù): 0
打印 上一主題 下一主題

Java實現(xiàn)對cookie的操作(增刪改查) [復(fù)制鏈接]

論壇徽章:
2
操作系統(tǒng)版塊每日發(fā)帖之星
日期:2015-06-26 22:20:00每日論壇發(fā)貼之星
日期:2015-06-26 22:20:00
跳轉(zhuǎn)到指定樓層
1 [收藏(0)] [報告]
發(fā)表于 2015-07-08 11:25 |只看該作者 |倒序瀏覽
[代碼]基于springMVC框架下寫的
  1. /**
  2.          * 讀取所有cookie
  3.          * 注意二、從客戶端讀取Cookie時,包括maxAge在內(nèi)的其他屬性都是不可讀的,也不會被提交。瀏覽器提交Cookie時只會提交name與value屬性。maxAge屬性只被瀏覽器用來判斷Cookie是否過期
  4.          * @param request
  5.          * @param response
  6.          */
  7.         @RequestMapping("/showCookies")
  8.         public void showCookies(HttpServletRequest request,HttpServletResponse response ){
  9.             
  10.             Cookie[] cookies = request.getCookies();//這樣便可以獲取一個cookie數(shù)組
  11.             if (null==cookies) {
  12.                 System.out.println("沒有cookie=========");
  13.             } else {
  14.                 for(Cookie cookie : cookies){
  15.                     System.out.println("name:"+cookie.getName()+",value:"+ cookie.getValue());
  16.                 }
  17.             }
  18.             
  19.         }
  20.         /**
  21.          * 添加cookie
  22.          * @param response
  23.          * @param name
  24.          * @param value
  25.          */
  26.         @RequestMapping("/addCookie")
  27.         public void addCookie(HttpServletResponse response,String name,String value){
  28.             Cookie cookie = new Cookie(name.trim(), value.trim());
  29.             cookie.setMaxAge(30 * 60);// 設(shè)置為30min
  30.             cookie.setPath("/");
  31.             System.out.println("已添加===============");
  32.             response.addCookie(cookie);
  33.         }
  34.         /**
  35.          * 修改cookie
  36.          * @param request
  37.          * @param response
  38.          * @param name
  39.          * @param value
  40.          * 注意一、修改、刪除Cookie時,新建的Cookie除value、maxAge之外的所有屬性,例如name、path、domain等,都要與原Cookie完全一樣。否則,瀏覽器將視為兩個不同的Cookie不予覆蓋,導(dǎo)致修改、刪除失敗。
  41.          */
  42.         @RequestMapping("/editCookie")
  43.         public void editCookie(HttpServletRequest request,HttpServletResponse response,String name,String value){
  44.             Cookie[] cookies = request.getCookies();
  45.             if (null==cookies) {
  46.                 System.out.println("沒有cookie==============");
  47.             } else {
  48.                 for(Cookie cookie : cookies){
  49.                     if(cookie.getName().equals(name)){
  50.                         System.out.println("原值為:"+cookie.getValue());
  51.                         cookie.setValue(value);
  52.                         cookie.setPath("/");
  53.                         cookie.setMaxAge(30 * 60);// 設(shè)置為30min
  54.                         System.out.println("被修改的cookie名字為:"+cookie.getName()+",新值為:"+cookie.getValue());
  55.                         response.addCookie(cookie);
  56.                         break;
  57.                     }
  58.                 }
  59.             }
  60.             
  61.         }
  62.         /**
  63.          * 刪除cookie
  64.          * @param request
  65.          * @param response
  66.          * @param name
  67.          */
  68.         @RequestMapping("/delCookie")
  69.         public void delCookie(HttpServletRequest request,HttpServletResponse response,String name){
  70.             Cookie[] cookies = request.getCookies();
  71.             if (null==cookies) {
  72.                 System.out.println("沒有cookie==============");
  73.             } else {
  74.                 for(Cookie cookie : cookies){
  75.                     if(cookie.getName().equals(name)){
  76.                         cookie.setValue(null);
  77.                         cookie.setMaxAge(0);// 立即銷毀cookie
  78.                         cookie.setPath("/");
  79.                         System.out.println("被刪除的cookie名字為:"+cookie.getName());
  80.                         response.addCookie(cookie);
  81.                         break;
  82.                     }
  83.                 }
  84.             }
  85.         }
復(fù)制代碼
[代碼]通常開發(fā)時先用以下的代碼將獲取的cookie進(jìn)行封裝
  1. /**
  2.      * 根據(jù)名字獲取cookie
  3.      * @param request
  4.      * @param name cookie名字
  5.      * @return
  6.      */
  7.     public  Cookie getCookieByName(HttpServletRequest request,String name){
  8.         Map<String,Cookie> cookieMap = ReadCookieMap(request);
  9.         if(cookieMap.containsKey(name)){
  10.             Cookie cookie = (Cookie)cookieMap.get(name);
  11.             return cookie;
  12.         }else{
  13.             return null;
  14.         }   
  15.     }
  16.       
  17.       
  18.       
  19.     /**
  20.      * 將cookie封裝到Map里面
  21.      * @param request
  22.      * @return
  23.      */
  24.     private  Map<String,Cookie> ReadCookieMap(HttpServletRequest request){  
  25.         Map<String,Cookie> cookieMap = new HashMap<String,Cookie>();
  26.         Cookie[] cookies = request.getCookies();
  27.         if(null!=cookies){
  28.             for(Cookie cookie : cookies){
  29.                 cookieMap.put(cookie.getName(), cookie);
  30.             }
  31.         }
  32.         return cookieMap;
  33.     }
復(fù)制代碼
您需要登錄后才可以回帖 登錄 | 注冊

本版積分規(guī)則 發(fā)表回復(fù)

  

北京盛拓優(yōu)訊信息技術(shù)有限公司. 版權(quán)所有 京ICP備16024965號-6 北京市公安局海淀分局網(wǎng)監(jiān)中心備案編號:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年舉報專區(qū)
中國互聯(lián)網(wǎng)協(xié)會會員  聯(lián)系我們:huangweiwei@itpub.net
感謝所有關(guān)心和支持過ChinaUnix的朋友們 轉(zhuǎn)載本站內(nèi)容請注明原作者名及出處

清除 Cookies - ChinaUnix - Archiver - WAP - TOP