偷偷摘套内射激情视频,久久精品99国产国产精,中文字幕无线乱码人妻,中文在线中文a,性爽19p

用JSP控制Cookie的讀和寫(xiě)操作

開(kāi)發(fā) 前端
本文向大家描述一下如何用JSP操作Cookie,Cookie應(yīng)該是一種應(yīng)用較久的技術(shù)了。早在HTML剛剛出現(xiàn)的時(shí)候,在每個(gè)獨(dú)立的頁(yè)面之間沒(méi)有辦法記錄和標(biāo)識(shí)不同的用戶(hù)。

當(dāng)用戶(hù)訪(fǎng)問(wèn)網(wǎng)頁(yè)時(shí),它能夠在訪(fǎng)問(wèn)者的機(jī)器上創(chuàng)立一個(gè)文件,我們把它叫作Cookie,寫(xiě)一段內(nèi)容進(jìn)去,來(lái)標(biāo)識(shí)不同的用戶(hù)。如果下次用戶(hù)再訪(fǎng)問(wèn)這個(gè)網(wǎng)頁(yè)的時(shí)候,它又能夠讀出這個(gè)文件里面的內(nèi)容,這樣網(wǎng)頁(yè)就知道上次這個(gè)用戶(hù)已經(jīng)訪(fǎng)問(wèn)過(guò)該網(wǎng)頁(yè)了。

用JSP操作Cookie

一、前言

  說(shuō)起來(lái),Cookie應(yīng)該是一種應(yīng)用較久的技術(shù)了。早在HTML剛剛出現(xiàn)的時(shí)候,在每個(gè)獨(dú)立的頁(yè)面之間沒(méi)有辦法記錄和標(biāo)識(shí)不同的用戶(hù)。后來(lái)人們就發(fā)明了Cookie技術(shù),當(dāng)用戶(hù)訪(fǎng)問(wèn)網(wǎng)頁(yè)時(shí),它能夠在訪(fǎng)問(wèn)者的機(jī)器上創(chuàng)立一個(gè)文件,我們把它叫作Cookie,寫(xiě)一段內(nèi)容進(jìn)去,來(lái)標(biāo)識(shí)不同的用戶(hù)。如果下次用戶(hù)再訪(fǎng)問(wèn)這個(gè)網(wǎng)頁(yè)的時(shí)候,它又能夠讀出這個(gè)文件里面的內(nèi)容,這樣網(wǎng)頁(yè)就知道上次這個(gè)用戶(hù)已經(jīng)訪(fǎng)問(wèn)過(guò)該網(wǎng)頁(yè)了。

  雖然現(xiàn)在網(wǎng)頁(yè)的制作技術(shù)比起幾年以前已經(jīng)發(fā)展了許多。不過(guò)有些時(shí)候,Cookie還是能夠幫我們很多忙的。接下來(lái),我們就來(lái)看看,如何在寫(xiě)JSP文件的時(shí)候,用JSP操作Cookie.
  
二、寫(xiě)入Cookie

  其實(shí)用JSP操作Cookie是非常簡(jiǎn)單的,我們來(lái)看下面一段JSP程序:

  1. <html> 
  2.   <head>……(中間略)  
  3.   </head> 
  4.   <body> 
  5.   <%  
  6.   StringcookieName="Sender";  
  7.   Cookiecookie=newCookie(cookieName,"Test_Content");  
  8.   cookie.setMaxAge(10);  
  9.   response.addCookie(cookie);  
  10.   %> 
  11.   ……(其他內(nèi)容)  
  12.   </body> 
  13.   </html> 
  14.  

   這樣我們就設(shè)置了一個(gè)Cookie,很簡(jiǎn)單吧?

  我們來(lái)仔細(xì)研究一下這段代碼:

  1.   Cookiecookie=newCookie(cookieName,"Test_Content");  
  2.  

  這一行建立了一個(gè)Cookie對(duì)象,初始化有兩個(gè)參數(shù),***個(gè)參數(shù)cookieName定義了Cookie的名字,后一個(gè)參數(shù),也是一個(gè)字符串,定義了Cookie的內(nèi)容。也就是我們希望網(wǎng)頁(yè)在用戶(hù)的機(jī)器上標(biāo)識(shí)的文件內(nèi)容。

接下來(lái)一行:cookie.setMaxAge(10),調(diào)用了Cookie中的setMaxAge方法,設(shè)定Cookie在用戶(hù)機(jī)器硬盤(pán)上的存活期為10秒。一個(gè)Cookie在用戶(hù)的硬盤(pán)里面存在的時(shí)間并不是無(wú)限期的,在建立Cookie對(duì)象的時(shí)候,我們必須制定Cookie的存活期,超過(guò)了這個(gè)存活期后,Cookie文件就不再起作用,會(huì)被用戶(hù)的瀏覽器自行刪除。如果我們希望用戶(hù)在下次訪(fǎng)問(wèn)這個(gè)頁(yè)面的時(shí)候,Cookie文件仍然有效而且可以被網(wǎng)頁(yè)讀出來(lái)的話(huà),我們可以將Cookie的存活期設(shè)得稍微長(zhǎng)一些。比如cookie.setMaxAge(365*24*60*60)可以讓Cookie文件在一年內(nèi)有效。#p#

三、讀出Cookie

  Cookie文件創(chuàng)建好后,自然還需要我們把它讀出來(lái),否則我們不是白費(fèi)力氣嗎?接下來(lái)我們看看如何讀出在用戶(hù)硬盤(pán)上的Cookie.

  1. <html> 
  2.   <head>……(中間略)  
  3.   </head> 
  4.   <body> 
  5.   <tablebordertableborder=1> 
  6.   <tr><td>Name</td><td>value</td></tr> 
  7.   <%  
  8.   Cookiecookies[]=request.getCookies();  
  9.   CookiesCookie=null;  
  10.   Stringsvalue=null;  
  11.   Stringsname=null;  
  12.   for(inti=0;i<cookies.length;i++)  
  13.   {  
  14.   sCookie=cookies[i];  
  15.   svalue=sCookie.getValue();  
  16.   sname=sCookie.getName();  
  17.   %> 
  18.   <tr><td><%=sname%></td><td><%=svalue%></td></tr> 
  19.   <%  
  20.   }  
  21.   %> 
  22.   </table>……(其他內(nèi)容)  
  23.   </body> 
  24.   </html> 
  25.  

 這一小段JSP文件可以讀出用戶(hù)硬盤(pán)上的所有有效的Cookie,也就是仍然在存活期內(nèi)的Cookie文件。并用表格的形式列出每個(gè)Cookie的名字和內(nèi)容。

  我們來(lái)逐行分析一下這段代碼:

  1.   Cookiecookies[]=request.getCookies()  
  2.  

       我們用request.getCookies()讀出用戶(hù)硬盤(pán)上的Cookie,并將所有的Cookie放到一個(gè)cookie對(duì)象數(shù)組里面。

  接下來(lái)我們用一個(gè)循環(huán)語(yǔ)句遍歷剛才建立的Cookie對(duì)象數(shù)組,我們用sCookie=cookies[i]取出數(shù)組中的一個(gè)Cookie對(duì)象,然后我們用sCookie.getValue()和sCookie.getName()兩個(gè)方法來(lái)取得這個(gè)Cookie的名字和內(nèi)容。

  通過(guò)將取出來(lái)的Cookie的名字和內(nèi)容放在字符串變量中,我們就能對(duì)其進(jìn)行各種操作了。在上面的例子里,可通過(guò)循環(huán)語(yǔ)句的遍歷,將所有Cookie放在一張表格中進(jìn)行顯示。#p#

四、需要注意的一些問(wèn)題

  通過(guò)上面兩個(gè)簡(jiǎn)單的例子,可以看到,用JSP進(jìn)行Cookie的操作,是非常簡(jiǎn)單的。不過(guò)我們?cè)趯?shí)際操作中還要注意一些問(wèn)題:

1.Cookie的兼容性問(wèn)題

  Cookie的格式有2個(gè)不同的版本,***個(gè)版本,我們稱(chēng)為CookieVersion0,是最初由Netscape公司制定的,也被幾乎所有的瀏覽器支持。而較新的版本,CookieVersion1,則是根據(jù)RFC2109文檔制定的。為了確保兼容性,JAVA規(guī)定,前面所提到的涉及Cookie的操作都是針對(duì)舊版本的Cookie進(jìn)行的。而新版本的Cookie目前還不被Javax.servlet.http.Cookie包所支持。

2.Cookie的內(nèi)容

  同樣的Cookie的內(nèi)容的字符限制針對(duì)不同的Cookie版本也有不同。在CookieVersion0中,某些特殊的字符,例如:空格,方括號(hào),圓括號(hào),等于號(hào)(=),逗號(hào),雙引號(hào),斜杠,問(wèn)號(hào),@符號(hào),冒號(hào),分號(hào)都不能作為Cookie的內(nèi)容。這也就是為什么我們?cè)诶又性O(shè)定Cookie的內(nèi)容為“Test_Content”的原因。

  雖然在CookieVersion1規(guī)定中放寬了限制,可以使用這些字符,但是考慮到新版本的Cookie規(guī)范目前仍然沒(méi)有為所有的瀏覽器所支持,因而為保險(xiǎn)起見(jiàn),我們應(yīng)該在Cookie的內(nèi)容中盡量避免使用這些字符。

【編輯推薦】

  1. 使用Javascript巧妙獲取滾動(dòng)條位置
  2. 深入探究cookie技術(shù)在J2ME平臺(tái)的應(yīng)用與實(shí)現(xiàn)
  3. IE6.0中使用Javascript支持png格式圖片
  4. Java中的cookie管理庫(kù)與J2ME結(jié)合
  5. Javascript巧妙解決img做網(wǎng)站異常提交問(wèn)題

 

責(zé)任編輯:佚名 來(lái)源: tech.ddvip.com
相關(guān)推薦

2021-01-28 18:06:49

JavaScriptCookieWeb

2009-07-01 18:17:32

JSP處理Cookie

2009-07-01 15:13:10

JSP留言板

2010-10-09 15:31:51

JavaScriptCookie

2009-07-06 16:05:50

JSP特點(diǎn)

2009-07-01 18:01:20

JSP代碼塊緩沖OSCache

2009-02-11 10:08:53

Cookie屬性JSP

2024-02-23 08:36:34

Python鼠標(biāo)鍵盤(pán)

2009-07-06 15:34:56

JSP和Servlet

2009-07-01 14:32:37

JSP文件操作

2025-01-03 09:39:04

2009-12-10 17:27:39

PHP操作Cookie

2010-08-24 16:07:53

2009-06-18 15:49:31

jQuery插件

2009-07-08 09:22:03

Servlet和JSP

2012-05-04 08:25:35

LinuxUnix

2009-07-31 16:45:23

ASP.NET數(shù)據(jù)庫(kù)操

2010-06-02 13:13:40

Cassandra

2009-06-15 15:54:53

Java中Cookie

2013-08-21 09:21:01

點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)