欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

非常不錯(cuò)的[JS]Cookie精通之路第1/2頁

 更新時(shí)間:2008年06月26日 08:55:56   作者:  
Cookies,有些人喜歡它們,有些人憎恨它們。但是,很少有人真正知道如何使用它們?,F(xiàn)在你可以成為少數(shù)人中的成員-可以自傲的 Cookie 大師。
如果你象作者一樣記性不好,那么你可能根本記不住人們的名字。我遇到人時(shí),多半只是點(diǎn)點(diǎn)頭,問句“吃了嘛!”,而且期望問候到此為止
。如果還需要表示些什么,那么我就得求助于一些狡猾的技巧,好讓我能想對方是誰。比如胡扯起一些和對方有關(guān)的人,不管他們之間關(guān)系多
遠(yuǎn),只要能避免不記得對方名字的尷尬就好: “你隔壁鄰居的侄子的可愛小狗邁菲斯特怎么樣?”通過這個(gè)方法,我希望能讓對方感到,我確
實(shí)很重視他(她),甚至還記得這些瑣事,雖然實(shí)際上連名字都忘記了。但是,不是我不重視,而是我的記憶力實(shí)在是糟糕,而且要記住的名
字又實(shí)在太多。如果我能給每個(gè)人設(shè)置cookies,那么我就不會(huì)再犯這種記憶力問題了。

在這篇文章里,我們要學(xué)習(xí):

1. 什么是 Cookies?
2. Cookie 的構(gòu)成
3. 操縱 Cookies
4. Cookie 怪獸

什么是Cookies?

你會(huì)問,什么是cookies呢? cookie 是瀏覽器保存在用戶計(jì)算機(jī)上的少量數(shù)據(jù)。它與特定的WEB頁或WEB站點(diǎn)關(guān)聯(lián)起來,自動(dòng)地在WEB瀏覽器和
WEB服務(wù)器之間傳遞。

比如,如果你運(yùn)行的是Windows操作系統(tǒng),使用Internet Explorer上網(wǎng),那么你會(huì)發(fā)現(xiàn)在你的“Windows”目錄下面有一個(gè)子目錄,叫做
“Temporary Internet Files”。如果你有空看看這個(gè)目錄,就會(huì)發(fā)現(xiàn)里面有一些文件,文件名稱看起來就象電子郵件地址。比如在我機(jī)器上
的這個(gè)目錄里,就有 “jim@support.microsoft.com”這樣的文件。這是一個(gè)cookie 文件,這個(gè)文件從哪來呢?猜一猜,它來自微軟的支持站
點(diǎn)。順便說一句,這不是我的電子郵件地址,特此澄清。

對于管理細(xì)小的、不重要的、不想保存在中央數(shù)據(jù)庫里的細(xì)節(jié)信息,Cookies 是個(gè)很不錯(cuò)的方案。(這不是說大家的名字不重要。)比如,目
前網(wǎng)站上不斷增長的自定義服務(wù),可以為每個(gè)用戶定制他們要看的內(nèi)容。如果你設(shè)計(jì)的就是這樣一個(gè)站點(diǎn),那么你怎么來管理這樣的信息:一
個(gè)用戶喜歡綠色的菜單條,而另一個(gè)喜歡紅色的。確實(shí)是個(gè)累人的問題。不過,這樣的信息,可以很安全地記錄到cookie,并保存在用戶的計(jì)
算機(jī)上,而你自己的數(shù)據(jù)庫空間可以留給更長久更有意義的數(shù)據(jù)。

FYI: Cookies 對于安全用途,通常很有用。我不想在此就這一問題過于深入,只是提供一個(gè)示例,可以看到如何使用在一段時(shí)間之后過期的
cookies來保證站點(diǎn)安全:

1. 使用用戶名和口令,通過 SSL 登錄。
2. 在服務(wù)器的數(shù)據(jù)庫里檢查用戶名和口令。如果登錄成功,建立一個(gè)當(dāng)前時(shí)間標(biāo)簽的消息摘要 (比如 MD5) ,并把它保存在cookie和服務(wù)器數(shù)
據(jù)庫里。把用戶的登錄時(shí)間保存在服務(wù)器數(shù)據(jù)庫里面的用戶記錄里。
3. 在進(jìn)行每個(gè)安全事務(wù)時(shí)(用戶處于登錄狀態(tài)的任何事務(wù)),把cookie的消息摘要和保存在服務(wù)器數(shù)據(jù)庫里的摘要進(jìn)行比較,如果比較失敗,
就把用戶引導(dǎo)到登錄界面。
4. 如果第3步檢查通過,那么檢查當(dāng)前時(shí)間和登錄時(shí)間之音經(jīng)過的時(shí)間是否超過允許的時(shí)間長度。如果用戶已經(jīng)超時(shí),那么就把用戶引到登錄
界面。
5. 如果第3步和第4步都通過了,那么把登錄時(shí)間重新設(shè)置成當(dāng)前時(shí)間,允許事務(wù)發(fā)生。那些需要你登錄的安全站點(diǎn),可能多數(shù)使用的都是和這
里介紹的類似的方法。
Cookie的構(gòu)成

Cookies最初設(shè)計(jì)時(shí),是為了CGI編程。但是,我們也可以使用Javascript腳本來操縱cookies。在本文里,我們將演示如何使用Javascript腳本
來操縱cookies。(如果有需求,我可能會(huì)在以后的文章里介紹如何使用Perl進(jìn)行cookie管理。但是如果實(shí)在等不得,那么我現(xiàn)在就教你一手:
仔細(xì)看看CGI.pm。在這個(gè)CGI包里有一個(gè)cookie()函數(shù),可以用它建立cookie。但是,還是讓我們先來介紹cookies的本質(zhì)。

在Javascript腳本里,一個(gè)cookie 實(shí)際就是一個(gè)字符串屬性。當(dāng)你讀取cookie的值時(shí),就得到一個(gè)字符串,里面當(dāng)前WEB頁使用的所有cookies
的名稱和值。每個(gè)cookie除了name名稱和value值這兩個(gè)屬性以外,還有四個(gè)屬性。這些屬性是: expires過期時(shí)間、 path路徑、 domain域、
以及 secure安全。

Expires – 過期時(shí)間。指定cookie的生命期。具體是值是過期日期。如果想讓cookie的存在期限超過當(dāng)前瀏覽器會(huì)話時(shí)間,就必須使用這個(gè)屬
性。當(dāng)過了到期日期時(shí),瀏覽器就可以刪除cookie文件,沒有任何影響。

Path – 路徑。指定與cookie關(guān)聯(lián)的WEB頁。值可以是一個(gè)目錄,或者是一個(gè)路徑。如果http://www.zdnet.com/devhead/index.html 建立了一
個(gè)cookie,那么在http://www.zdnet.com/devhead/目錄里的所有頁面,以及該目錄下面任何子目錄里的頁面都可以訪問這個(gè)cookie。這就是說
,在http://www.zdnet.com/devhead/stories/articles 里的任何頁面都可以訪問http://www.zdnet.com/devhead/index.html建立的cookie。
但是,如果http://www.zdnet.com/zdnn/ 需要訪問http://www.zdnet.com/devhead/index.html設(shè)置的cookes,該怎么辦?這時(shí),我們要把
cookies 的path屬性設(shè)置成“/”。在指定路徑的時(shí)候,凡是來自同一服務(wù)器,URL里有相同路徑的所有WEB頁面都可以共享cookies。現(xiàn)在看另
一個(gè)例子:如果想讓 http://www.zdnet.com/devhead/filters/ 和http://www.zdnet.com/devhead/stories/共享cookies,就要把path設(shè)成“
/devhead”。

Domain – 域。指定關(guān)聯(lián)的WEB服務(wù)器或域。值是域名,比如zdnet.com。這是對path路徑屬性的一個(gè)延伸。如果我們想讓 
catalog.mycompany.com 能夠訪問shoppingcart.mycompany.com設(shè)置的cookies,該怎么辦? 我們可以把domain屬性設(shè)置成“mycompany.com”
,并把path屬性設(shè)置成“/”。FYI:不能把cookies域?qū)傩栽O(shè)置成與設(shè)置它的服務(wù)器的所在域不同的值。

Secure – 安全。指定cookie的值通過網(wǎng)絡(luò)如何在用戶和WEB服務(wù)器之間傳遞。這個(gè)屬性的值或者是“secure”,或者為空。缺省情況下,該屬
性為空,也就是使用不安全的HTTP連接傳遞數(shù)據(jù)。如果一個(gè) cookie 標(biāo)記為secure,那么,它與WEB服務(wù)器之間就通過HTTPS或者其它安全協(xié)議
傳遞數(shù)據(jù)。不過,設(shè)置了secure屬性不代表其他人不能看到你機(jī)器本地保存的cookie。換句話說,把cookie設(shè)置為secure,只保證cookie與WEB
服務(wù)器之間的數(shù)據(jù)傳輸過程加密,而保存在本地的cookie文件并不加密。如果想讓本地cookie也加密,得自己加密數(shù)據(jù)。




操縱Cookies

請記住,cookie就是文檔的一個(gè)字符串屬性。要保存cookie,只要建立一個(gè)字符串,格式是name=<value>(名稱=值),然后把文檔的 
document.cookie 設(shè)置成與它相等即可。比如,假設(shè)想保存表單接收到的用戶名,那么代碼看起來就象這樣:

document.cookie = "username" + escape(form.username.value);

在這里,使用 escape() 函數(shù)非常重要,因?yàn)閏ookie值里可能包含分號、逗號或者空格。這就是說,在讀取cookie值時(shí),必須使用對應(yīng)的
unescape()函數(shù)給值解碼。

我們當(dāng)然還得介紹cookie的四個(gè)屬性。這些屬性用下面的格式加到字符串值后面:

name=<value>[; expires=<date>][; domain=<domain>][; path=<path>][; secure]

名稱=<值>[; expires=<日期>][; domain=<域>][; path=<路徑>][; 安全]

<value>, <date>, <domain> 和 <path> 應(yīng)當(dāng)用對應(yīng)的值替換。<date> 應(yīng)當(dāng)使用GMT格式,可以使用Javascript腳本語言的日期類Date
的.toGMTString() 方法得到這一GMT格式的日期值。方括號代表這項(xiàng)是可選的。比如在 [; secure]兩邊的方括號代表要想把cookie設(shè)置成安全
的,就需要把"; secure" 加到cookie字符串值的后面。如果"; secure" 沒有加到cookie字符串后面,那么這個(gè)cookie就是不安全的。不要把
尖括號<> 和方括號[] 加到cookie里(除非它們是某些值的內(nèi)容)。設(shè)置屬性時(shí),不限屬性,可以用任何順序設(shè)置。

下面是一個(gè)例子,在這個(gè)例子里,cookie "username" 被設(shè)置成在15分鐘之后過期,可以被服務(wù)器上的所有目錄訪問,可以被"mydomain.com"
域里的所有服務(wù)器訪問,安全狀態(tài)為安全。

相關(guān)文章

  • Javascript中的Callback方法淺析

    Javascript中的Callback方法淺析

    這篇文章主要介紹了Javascript中的Callback方法淺析,本文講解了什么是callback、Javscript Callback、Callback是什么、Callback實(shí)例等內(nèi)容,需要的朋友可以參考下
    2015-03-03
  • JavaScript中判斷函數(shù)是new還是()調(diào)用的區(qū)別說明

    JavaScript中判斷函數(shù)是new還是()調(diào)用的區(qū)別說明

    具名函數(shù)的各種調(diào)用方式 在之前篇幅中已經(jīng)介紹過了。這篇看看如何判斷一個(gè)函數(shù)是被new調(diào)用的,還是被其它方式調(diào)用的。
    2011-04-04
  • JavaScript判斷瀏覽器運(yùn)行環(huán)境的詳細(xì)方法

    JavaScript判斷瀏覽器運(yùn)行環(huán)境的詳細(xì)方法

    這篇文章主要給大家介紹了關(guān)于JavaScript判斷瀏覽器運(yùn)行環(huán)境的詳細(xì)方法,文中通過示例代碼介紹的非常詳細(xì),對大家學(xué)習(xí)或者使用JavaScript具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-06-06
  • javascript encodeURI和encodeURIComponent的比較

    javascript encodeURI和encodeURIComponent的比較

    在進(jìn)行SaaS前端開發(fā)的時(shí)候,大家經(jīng)常會(huì)用到兩個(gè)JavaScriptNative函數(shù):encodeURI 和 encodeURIComponent。這篇文章詳細(xì)解釋這兩個(gè)函數(shù)的用途并比較它們的不同之處
    2010-04-04
  • 微信小程序開發(fā)之你可能沒有踩過的神坑總結(jié)

    微信小程序開發(fā)之你可能沒有踩過的神坑總結(jié)

    最近在做一個(gè)小程序的項(xiàng)目,所以記錄下開發(fā)過程中遇到的坑,這篇文章主要給大家介紹了關(guān)于微信小程序開發(fā)之你可能沒有踩過的神坑,需要的朋友可以參考下
    2021-09-09
  • 微信小程序?qū)崿F(xiàn)頁面分享onShareAppMessage

    微信小程序?qū)崿F(xiàn)頁面分享onShareAppMessage

    這篇文章主要介紹了微信小程序?qū)崿F(xiàn)頁面分享onShareAppMessage,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-08-08
  • 微信小程序?qū)崿F(xiàn)翻牌抽獎(jiǎng)動(dòng)畫

    微信小程序?qū)崿F(xiàn)翻牌抽獎(jiǎng)動(dòng)畫

    這篇文章主要為大家詳細(xì)介紹了微信小程序?qū)崿F(xiàn)翻牌抽獎(jiǎng)動(dòng)畫,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2020-09-09
  • threejs太陽光與陰影效果實(shí)例代碼

    threejs太陽光與陰影效果實(shí)例代碼

    在Threejs中類似于我們現(xiàn)實(shí)世界,物體顯示的顏色是由物體本身的顏色及光照的顏色相互疊加而得到的,這篇文章主要給大家介紹了關(guān)于threejs太陽光與陰影效果的相關(guān)資料,需要的朋友可以參考下
    2022-04-04
  • 淺談js原生拖放

    淺談js原生拖放

    下面小編就為大家?guī)硪黄獪\談js原生拖放。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2016-11-11
  • 微信小程序npm引入vant-weapp的踩坑記錄

    微信小程序npm引入vant-weapp的踩坑記錄

    這篇文章主要給大家介紹了關(guān)于微信小程序npm引入vant-weapp的踩坑記錄,文中通過示例代碼介紹的非常詳細(xì),對大家學(xué)習(xí)或者使用微信小程序具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-08-08

最新評論