我們先要學(xué)一學(xué) Cookie 的基本知識(shí)。
每個(gè) Cookie 都是這樣的:<cookie名>=<值>
<cookie名>的限制與 javascript 的命名限制大同小異,少了“不能用 javascript 關(guān)鍵字”,多了“只能用可以用在 URL 編碼中的字符”。后者比較難懂,但是只要你只用字母和數(shù)字命名,就完全沒有問題了。<值>的要求也是“只能用可以用在 URL 編碼中的字符”。
每個(gè) Cookie 都有失效日期,一旦電腦的時(shí)鐘過了失效日期,這個(gè) Cookie 就會(huì)被刪掉。我們不能直接刪掉一個(gè) Cookie,但是可以用設(shè)定失效日期早于現(xiàn)在時(shí)刻的方法來間接刪掉它。
每個(gè)網(wǎng)頁,或者說每個(gè)站點(diǎn),都有它自己的 Cookies,這些 Cookies 只能由這個(gè)站點(diǎn)下的網(wǎng)頁來訪問,來自其他站點(diǎn)或同一站點(diǎn)下未經(jīng)授權(quán)的區(qū)域的網(wǎng)頁,是不能訪問的。每一“組”Cookies 有規(guī)定的總大小(大約 2KB 每“組”),一超過最大總大小,則最早失效的 Cookie 先被刪除,來讓新的 Cookie“安家”。
現(xiàn)在我們來學(xué)習(xí)使用 documents.cookie 屬性。
如果直接使用 document.cookie 屬性,或者說,用某種方法,例如給變量賦值,來獲得 document.cookie 的值,我們就可以知道在現(xiàn)在的文檔中有多少個(gè) Cookies,每個(gè) Cookies 的名字,和它的值。例如,在某文檔中添加“document.write(document.cookie)”,結(jié)果顯示:
name=kevin; email=kevin@kevin.com; lastvisited=index.html
這意味著,文檔包含 3 個(gè) Cookies:name, email 和 lastvisited,它們的值分別是 kevin, kevin@kevin.com 和 index.html。可以看到,兩個(gè) Cookies 之間是用分號(hào)和空格隔開的,于是我們可以用 cookieString.split('; ') 方法得到每個(gè) Cookie 分開的一個(gè)數(shù)組(先用 var cookieString = document.cookie)。
設(shè)定一個(gè) Cookie 的方法是對 documents.cookie 賦值。與其它情況下的賦值不同,向 documents.cookie 賦值不會(huì)刪除掉原有的 Cookies,而只會(huì)增添 Cookies 或更改原有 Cookie。賦值的格式:
+ ';expires=' + expirationDateObj.toGMTString();
首先 escape() 方法:為什么一定要用?因?yàn)?Cookie 的值的要求是“只能用可以用在 URL 編碼中的字符”。我們知道“escape()”方法是把字符串按 URL 編碼方法來編碼的,那我們只需要用一個(gè)“escape()”方法來處理輸出到 Cookie 的值,用“unescape()”來處理從 Cookie 接收過來的值就萬無一失了。而且這兩個(gè)方法的最常用途就是處理 Cookies。其實(shí)設(shè)定一個(gè) Cookie 只是“documents.cookie = 'cookieName=cookievalue'”這么簡單,但是為了避免在 cookievalue 中出現(xiàn) URL 里不準(zhǔn)出現(xiàn)的字符,還是用一個(gè) escape() 好。
然后“expires”前面的分號(hào):注意到就行了。是分號(hào)而不是其他。
最后 toGMTString() 方法:設(shè)定 Cookie 的時(shí)效日期都是用 GMT 格式的時(shí)間的,其它格式的時(shí)間是沒有作用的。
現(xiàn)在我們來實(shí)戰(zhàn)一下。設(shè)定一個(gè)“name=rose”的 Cookie,在 3 個(gè)月后過期。
expires.setTime(expires.getTime() + 3 * 30 * 24 * 60 * 60 * 1000);
/* 三個(gè)月 x 一個(gè)月當(dāng)作 30 天 x 一天 24 小時(shí)
x 一小時(shí) 60 分 x 一分 60 秒 x 一秒 1000 毫秒 */
documents.cookie = 'name=rose;expires=' + expires.toGMTString();
為什么沒有用 escape() 方法?這是因?yàn)槲覀冎?rose 是一個(gè)合法的 URL 編碼字符串,也就是說,'rose' == escape('rose')。一般來說,如果設(shè)定 Cookie 時(shí)不用 escape(),那獲取 Cookie 時(shí)也不用 unescape()。
再來一次:編寫一個(gè)函數(shù),作用是查找指定 Cookie 的值。
var cookieString = documents.cookie;
var start = cookieString.indexOf(cookieName + '=');
// 加上等號(hào)的原因是避免在某些 Cookie 的值里有
// 與 cookieName 一樣的字符串。
if (start == -1) // 找不到
return null;
start += cookieName.length + 1;
var end = cookieString.indexOf(';', start);
if (end == -1) return unescape(cookieString.substring(start));
return unescape(cookieString.substring(start, end));
}
這個(gè)函數(shù)用到了字符串對象的一些方法,如果你不記得了(你是不是這般沒記性啊),請快去查查。這個(gè)函數(shù)所有的 if 語句都沒有帶上 else,這是因?yàn)槿绻麠l件成立,程序運(yùn)行的都是 return 語句,在函數(shù)里碰上 return,就會(huì)終止運(yùn)行,所以不加 else 也沒問題。該函數(shù)在找到 Cookie 時(shí),就會(huì)返回 Cookie 的值,否則返回“null”。
現(xiàn)在我們要?jiǎng)h除剛才設(shè)定的 name=rose Cookie。
expires.setTime(expires.getTime() - 1);
documents.cookie = 'name=rose;expires=' + expires.toGMTString();
posted @ 2006-08-18 15:11 boddi 閱讀(144) | 評(píng)論 (0) | 編輯 收藏