jsp cookie 處理
cookie 是存儲在客戶機的文本文件,它們保存了大量軌跡信息。在 servlet 技術基礎上,jsp 顯然能夠提供對 http cookie 的支持。
通常有三個步驟來識別回頭客:
- 服務器腳本發送一系列 cookie 至瀏覽器。比如名字,年齡,id 號碼等等。
- 瀏覽器在本地機中存儲這些信息,以備不時之需。
- 當下一次瀏覽器發送任何請求至服務器時,它會同時將這些 cookie 信息發送給服務器,然后服務器使用這些信息來識別用戶或者干些其它事情。
本章節將會傳授您如何去設置或重設 cookie 的方法,還有如何訪問它們及如何刪除它們。
jsp cookie 處理需要對中文進行編碼與解碼,方法如下:
string str = java.net.urlencoder.encode("中文", "utf-8"); //編碼 string str = java.net.urldecoder.decode("編碼后的字符串","utf-8"); // 解碼
cookie 剖析
cookie 通常在 http 信息頭中設置(雖然 javascript 能夠直接在瀏覽器中設置 cookie)。在 jsp 中,設置一個 cookie 需要發送如下的信息頭給服務器:
http/1.1 200 ok date: fri, 04 feb 2015 21:03:38 gmt server: apache/1.3.9 (unix) php/4.0b3 set-cookie: name=yapf; expires=friday, 04-feb-17 22:03:38 gmt; path=/; domain=yapf.com connection: close content-type: text/html
正如您所見,set-cookie 信息頭包含一個鍵值對,一個 gmt(格林尼治標準)時間,一個路徑,一個域名。鍵值對會被編碼為url。有效期域是個指令,告訴瀏覽器在什么時候之后就可以清除這個 cookie。
如果瀏覽器被配置成可存儲 cookie,那么它將會保存這些信息直到過期。如果用戶訪問的任何頁面匹配了 cookie 中的路徑和域名,那么瀏覽器將會重新將這個 cookie 發回給服務器。瀏覽器端的信息頭長得就像下面這樣:
get / http/1.0 connection: keep-alive user-agent: mozilla/4.6 (x11; i; linux 2.2.6-15apmac ppc) host: zink.demon.co.uk:1126 accept: image/gif, */* accept-encoding: gzip accept-language: en accept-charset: iso-8859-1,*,utf-8 cookie: name=xyz
jsp 腳本通過 request 對象中的 getcookies() 方法來訪問這些 cookie,這個方法會返回一個 cookie 對象的數組。
servlet cookie 方法
下表列出了 cookie 對象中常用的方法:
序號 | 方法 & 描述 |
---|---|
1 | public void setdomain(string pattern) 設置 cookie 的域名,比如 yapf.com |
2 | public string getdomain() 獲取 cookie 的域名,比如 yapf.com |
3 | public void setmaxage(int expiry) 設置 cookie 有效期,以秒為單位,默認有效期為當前session的存活時間 |
4 | public int getmaxage() 獲取 cookie 有效期,以秒為單位,默認為-1 ,表明cookie會活到瀏覽器關閉為止 |
5 | public string getname() 返回 cookie 的名稱,名稱創建后將不能被修改 |
6 | public void setvalue(string newvalue) 設置 cookie 的值 |
7 | public string getvalue() 獲取cookie的值 |
8 | public void setpath(string uri) 設置 cookie 的路徑,默認為當前頁面目錄下的所有 url,還有此目錄下的所有子目錄 |
9 | public string getpath() 獲取 cookie 的路徑 |
10 | public void setsecure(boolean flag) 指明 cookie 是否要加密傳輸 |
11 | public void setcomment(string purpose) 設置注釋描述 cookie 的目的。當瀏覽器將 cookie 展現給用戶時,注釋將會變得非常有用 |
12 | public string getcomment() 返回描述 cookie 目的的注釋,若沒有則返回 null |
使用 jsp 設置 cookie
使用 jsp 設置 cookie 包含三個步驟:
(1)創建一個 cookie 對象: 調用 cookie 的構造函數,使用一個 cookie 名稱和值做參數,它們都是字符串。
cookie cookie = new cookie("key","value");
請務必牢記,名稱和值中都不能包含空格或者如下的字符:
[ ] ( ) = , " / ? @ : ;
(2) 設置有效期:調用 setmaxage() 函數表明 cookie 在多長時間(以秒為單位)內有效。下面的操作將有效期設為了 24 小時。
cookie.setmaxage(60*60*24);
(3) 將 cookie 發送至 http 響應頭中:調用 response.addcookie() 函數來向 http 響應頭中添加 cookie。
response.addcookie(cookie);
實例演示
main.jsp 文件代碼如下所示:
<%@ page language="java" contenttype="text/html; charset=utf-8" pageencoding="utf-8"%> <%@ page import="java.net.*" %> <% // 編碼,解決中文亂碼 string str = urlencoder.encode(request.getparameter("name"),"utf-8"); // 設置 name 和 url cookie cookie name = new cookie("name", str); cookie url = new cookie("url", request.getparameter("url")); // 設置cookie過期時間為24小時。 name.setmaxage(60*60*24); url.setmaxage(60*60*24); // 在響應頭部添加cookie response.addcookie( name ); response.addcookie( url ); %> <html> <head> <title>設置 cookie</title> </head> <body> <h1>設置 cookie</h1> <ul> <li><p><b>網站名:</b> <%= request.getparameter("name")%> </p></li> <li><p><b>網址:</b> <%= request.getparameter("url")%> </p></li> </ul> </body> </html>
以下是一個簡單的 html 表單通過 get 方法將客戶端數據提交到 main.jsp 文件中,并設置 cookie:
<!doctype html> <html> <head> <meta charset="utf-8"> <title>碩編程(yapf.com)</title> </head> <body> <form action="main.jsp" method=get> 站點名: <input type="text" name="name"> <br /> 網址: <input type="text" name="url" /> <input type="submit" value="提交" /> </form> </body> </html>
將以上 html 代碼保存到 test.htm 文件中。
將該文件放置于當前 jsp 項目的 webcontent 目錄下(與 main.jsp 同一個目錄)。
通過訪問 http://localhost:8080/testjsp/test.html 提交表單數據到 main.jsp 文件,演示 gif 圖如下所示:
試著輸入 "站點名" 和 "網址",然后點擊提交按鈕,它將會在您的屏幕中顯示 "站點名" 和 "網址",并且設置 "站點名" 和 "網址" 的兩個 cookie。
使用 jsp 讀取 cookie
想要讀取 cookie,您就需要調用 request.getcookies() 方法來獲得一個 javax.servlet.http.cookie 對象的數組,然后遍歷這個數組,使用 getname() 方法和 getvalue() 方法來獲取每一個 cookie 的名稱和值。