Ⅰ cookie能存多少數據
Internet Explorer允許cookie最長為4095個字元。
Firefox和Safari允許cookie最長為4097個字元,即cookie的名(name)和值(value)總共可以長達4096個字元。
Opera則允許cookie最長為4096個字元。
Ⅱ Cookie處理
Cookie存儲在客戶端,Cookie存儲的數據量有限,不同的瀏覽器存儲容量也不同,一般不超過4KB,因此Cookie只能存儲一些少量的數據。
Cookie可以保持用戶的登錄信息,待用戶下次訪問同一網站時,會發現不必輸入用戶名和密碼就已經登錄了。但有一些Cookie在用戶退出會話的時候就被刪除了(用戶也可手工刪除本地Cookie),這樣可以有效保護個人隱私。
Cookie在生成時會被指定一個Expire值,這就是Cookie的生存周期,在這個周期內Cookie有效,超出周期Cookie就會被清除。有些頁面將Cookie的生存周期設置為0或負值,這樣在關閉瀏覽器時就馬上清除Cookie,不會記錄用戶信息,更加安全。
Cookie所具有的屬性一般包括以下幾項。
·Domain:域,表示當前Cookie屬於哪個域或子域。對於伺服器返回的Set-Cookie,如果沒有指定Domain的值,那麼其Domain的值默認為當前所提交的HTTP請求所對應的主域名。例如訪問http://www.example.com,返回一個Cookie,如果沒有指名Domain的值,那麼其值為默認的www.example.com。
·Path:表示Cookie的所屬路徑。
·Expire time/Max-age:Cookie的有效期。Expire time的值是一個時間,過了這個時間該Cookie就失效了;或者是用Max-age指定當前Cookie在多長時間之後失效。如果伺服器返回的一個Cookie沒有指定其Expire time,那麼表明此Cookie的有效期只是當前的Session,即Session Cookie,當前Session會話結束後就過期了。對應的,當關閉(瀏覽器中)該頁面的時候,此Cookie就被瀏覽器刪除了。
·secure:表示該Cookie只能用HTTPS傳輸。一般用於包含認證信息的Cookie,要求傳輸此Cookie的時候必須用HTTPS傳輸。
·httponly:表示此Cookie必須用於HTTP或HTTPS傳輸。這意味著瀏覽器腳本(如javaScript中)是不允許訪問操作Cookie的。
對於一些需要輸入驗證碼才能登錄的網站,可以採用Cookie來解決問題。
·獲取Cookies的方法:get_cookies();
·獲取指定name的Cookie:driver.get_cookie(name);
·清除Cookie:delete_cookie()。
Ⅲ 瀏覽器中「Cookies"具體有什麼作用
瀏覽器中「Cookies"是指伺服器暫存放在你的電腦里的txt格式的文本文件資料,主要用於網路伺服器辨別電腦使用。比如瀏覽網站時,Cookies記錄下來你輸入的一些資料和信息。再訪問同一個網站,就會依據Cookie里的內容來判斷使用者,送出特定的信息內容給你。
平時上網時都是使用無狀態的HTTP協議傳輸出數據,這意味著客戶端與服務端在數據傳送完成後就會中斷連接。這時我們就需要一個一直保持會話連接的機制。
在session出現前,cookie就完全充當了這種角色。也就是,cookie的小量信息能幫助我們跟蹤會話。一般該信息記錄用戶身份。當然cookie也常記錄跟蹤購物車的商品信息(如數量)、記錄用戶訪問次數等。
Cookies一詞用在程序設計中是一種能夠讓網站伺服器把少量數據儲存到客戶端的硬碟或內存,或是從客戶端的硬碟讀取數據的一種技術。從本質上講,它可以看作是你的身份證。保存的信息片斷以"名/值"對(name-valuepairs)的形式儲存,一個"名/值"對僅僅是一條命名的數據。
一個網站只能取得它放在你的電腦中的信息,它無法從其它的Cookies文件中取得信息,也無法得到你的電腦上的其它任何東西。Cookies中的內容大多數經過了加密處理,因此一般用戶看來只是一些毫無意義的字母數字組合,只有伺服器的CGI處理程序才知道它們真正的含義。
硬碟中的Cookies文件可以被Web瀏覽器讀取,它的命名格式為:用戶名@網站地址[數字].txt。如筆者計算機中的一個Cookies文件名為:ch@163[1].txt。
/iknow-pic.cdn.bcebos.com/11385343fbf2b211a819ab3fc48065380cd78e8f"target="_blank"title="點擊查看大圖"class="illustration_alink">/iknow-pic.cdn.bcebos.com/11385343fbf2b211a819ab3fc48065380cd78e8f?x-bce-process=image%2Fresize%2Cm_lfit%2Cw_600%2Ch_800%2Climit_1%2Fquality%2Cq_85%2Fformat%2Cf_auto"esrc="https://iknow-pic.cdn.bcebos.com/11385343fbf2b211a819ab3fc48065380cd78e8f"/>
(3)cookie存大數據擴展閱讀:
Cookies的應用
1、網站瀏覽人數管理。由於代理伺服器、緩存等的使用,能幫助網站精確統計來訪人數的方法就是為每個訪問者建立一個的ID。使用Cookie,網站可以完成以下工作:測定多少人訪問過;測定訪問者中有多少是新用戶(即第一次來訪),多少是老用戶;測定一個用戶多久訪問一次網站。
通常情況下,網站設計者是藉助後台資料庫來實現以上目的的。當用戶第一次訪問該網站時,網站在資料庫中建立一個新的ID,並把ID通過Cookie傳送給用戶。用戶再次來訪時,網站把該用戶ID對應的計數器加1,得到用戶的來訪次數或判斷用戶是新用戶還是老用戶。
2、Cookies被刪除時。假如你的瀏覽器不能正常工作,你可能會刪除電腦上所有的臨時Internet文件。然而,一旦這樣操作以後,你就會丟掉所有的Cookies文件。
當你再次訪問一個網站時,網站會認為你是一位新用戶並分配給你一個新的用戶ID以及一個新的Cookie。結果將會造成網站統計的新老用戶比發生偏差,而你也難以恢復過去保存的參數選擇。
3、一人使用多台電腦時。有的人一天之中經常使用一台以上的電腦。例如在辦公室里有一台電腦、家裡有一台、還有移動辦公用的筆記本電腦。
除非網站使用了特別的技術來解決這一問題,否則,你將會有三個不同的Cookies文件在這三台機器上,而在三台機器上訪問過的任何網站都將會把你看成三個不同的用戶。
Ⅳ 面試二 session和cookie都存放什麼數據
秋夜曲(王維)
Ⅳ 陳述A:你不可能在cookie中存儲大量的數據。陳述B:Cookies只有有限的內存,最多可存4096位元組。評價上面的
A和B都是對的.COOKIE本身就不是保存大數據用的.所以A是對的.COOKIES最大隻有4K.所以也是對的.選C.
Ⅵ 計算機用語中biscuits ,cookie是什麼意思
biscuits沒聽說過,估計是跟cookie一樣的意思
cookie原意餅干,在網路編程中是指儲存在用戶本地終端上的數據,當你瀏覽網站時網站就會讓你的瀏覽器把你在網路上的一些登錄信息(記住密碼這種)或者設置之類的寫在你的磁碟里,這些信息就是cookie,下一次打開網站時把這些cookie發個伺服器,伺服器就用你的密碼幫你自動登錄了。cookie可以存登錄信息,語言,搜索記錄,一些大數據(如經常搜索的關鍵字)等。
Cookie,有時也用其復數形式Cookies。類型為「小型文本文件」,是某些網站為了辨別用戶身份,進行Session跟蹤而儲存在用戶本地終端上的數據(通常經過加密),由用戶客戶端計算機暫時或永久保存的信息。
Cookie 並不是它的原意「甜餅」的意思, 而是一個保存在客戶機中的簡單的文本文件, 這個文件與特定的Web文檔關聯在一起, 保存了該客戶機訪問這個Web 文檔時的信息, 當客戶機再次訪問這個 Web 文檔時這些信息可供該文檔使用。由於「Cookie」具有可以保存在客戶機上的神奇特性, 因此它可以幫助我們實現記錄用戶個人信息的功能, 而這一切都不必使用復雜的CGI等程序。
舉例來說, 一個 Web 站點可能會為每一個訪問者產生一個唯一的ID, 然後以 Cookie 文件的形式保存在每個用戶的機器上。如果使用瀏覽器訪問 Web, 會看到所有保存在硬碟上的 Cookie。在這個文件夾里每一個文件都是一個由「名/值」對組成的文本文件,另外還有一個文件保存有所有對應的 Web 站點的信息。在這里的每個 Cookie 文件都是一個簡單而又普通的文本文件。透過文件名, 就可以看到是哪個 Web 站點在機器上放置了Cookie(當然站點信息在文件里也有保存)。
部分信息來源:網路
Ⅶ cookie能存多大
一、瀏覽器允許每個域名所包含的cookie數:
Microsoft指出InternetExplorer8增加cookie限制為每個域名50個,但IE7似乎也允許每個域名50個cookie。
Firefox每個域名cookie限制為50個。
Opera每個域名cookie限制為30個。
Safari/WebKit貌似沒有cookie限制。但是如果cookie很多,則會使header大小超過伺服器的處理的限制,會導致錯誤發生。
註:「每個域名cookie限制為20個」將不再正確!
二、當很多的cookie被設置,瀏覽器如何去響應。
除Safari(可以設置全部cookie,不管數量多少),有兩個方法:
最少最近使用(leastrecentlyused(LRU))的方法:當Cookie已達到限額,自動踢除最老的Cookie,以使給最新的Cookie一些空間。InternetExplorer和Opera使用此方法。
Firefox很獨特:雖然最後的設置的Cookie始終保留,但似乎隨機決定哪些cookie被保留。似乎沒有任何計劃(建議:在Firefox中不要超過Cookie限制)。
三、不同瀏覽器間cookie總大小也不同:
Firefox和Safari允許cookie多達4097個位元組,包括名(name)、值(value)和等號。
Opera允許cookie多達4096個位元組,包括:名(name)、值(value)和等號。
InternetExplorer允許cookie多達4095個位元組,包括:名(name)、值(value)和等號。
註:多位元組字元計算為兩個位元組。在所有瀏覽器中,任何cookie大小超過限制都被忽略,且永遠不會被設置。
另!!!
WINDOWS所有的文件都會有一個實際大小和儲存大小。一般Cookie是文本文件,裡面也就幾行代碼,應該只有幾十位元組(bytes),但是WINDOWS會在緩存檔里把這個文件定義到KB的級別了
Ⅷ Cookie——儲存在用戶本地終端上的數據
cookie生命周期:
默認情況下生命周期是一次會話(瀏覽器被關閉)
如果通過expires=設置了時間則下次打開還會存在
注意: 設置時間為歷史時間相當於刪除了cookie
cookie注意點:
cookie默認不會保存任何的數據
cookie不能一次性設置多條數據,要想保存多條數據,只能一條條設置
cookie有大小和個數的限制
個數限制:20~50
大小限制:40kb左右
cookie作用范圍:
同一個瀏覽器的同一個路徑下訪問,
如果在同一個瀏覽器中,默認情況下下一個路徑也可以直接訪問
如果想保存在根路徑
document.cookie='name=zhangsan;path=/;'
如果想在不同域名的同一網站也保存cookie
應該寫ocument.cookie='name=zhangsan;path=/;domain=.com『;
(指定了根域名)
Ⅸ 緩存 是session 還是 cookie
以前實現數據的緩存有很多種方法,有客戶端的Cookie,有伺服器端的Session和Application。
其中Cookie是保存在客戶端的一組數據,主要用來保存用戶名等個人信息。
Session則保存對話信息。Application則是保存在整個應用程序范圍內的信息,相當於全局變數。
Session
Session用來保存每一個用戶的專有信息
Session的生存期是用戶持續請求時間加上一段時間(一般是20分鍾左右)
Session信息是保存在Web伺服器內存中的,保存數據量可大可小
由於用戶停止使用應用程序之後它仍在內存中存留一段時間,因此這種方法效率較低
代碼:
Session[「UserID」]=」test」;
String UserName=Session[「UserID」].ToString();
Cookie
Cookie用來保存客戶瀏覽器請求伺服器頁面的請求信息
我們可以存放非敏感的用戶信息,保存時間可以根據需要設置
如果沒有設置Cookie失效日期,它的生命周期保存到關閉瀏覽器為止
Cookie對象的Expires屬性設置為MinValue表示永不過期
Cookie存儲的數據量受限制,大多數的瀏覽器為4K因此不要存放大數據
由於並非所有的瀏覽器都支持Cookie,數據將以明文的形式保存在客戶端
代碼:
Resopnse.Cookies[「UserID」]=」test」;
String UserName= Resopnse.Cookies [「UserID」].ToString();
Cache
Cache用於在Http請求期間保存頁面或者數據
Cache的使用可以大大的提高整個應用程序的效率
它允許將頻繁訪問的伺服器資源存儲在內存中,當用戶發出相同的請求後,伺服器不是再次處理而是將Cache中保存的數據直接返回給用戶
可以看出Cache節省的是時間—伺服器處理時間
Cache實例是每一個應用程序專有的,其生命周期==該應用程序周期
應用程序重啟將重新創建其實例
注意:如果要使用緩存的清理、到期管理、依賴項等功能必須使用Insert 或者Add方法方法添加信息
代碼:
Cache[」ID」]=」cc」;或者Cache.Insert(「ID」,」test」);
String ID =Cache[「ID」].ToString();
通常使用最頻繁的是Session,那麼Session和Cache又有什麼區別呢?
Session緩存和Cache緩存的區別。
(1)最大的區別是Cache提供緩存依賴來更新數據,而Session只能依靠定義的緩存時間來判斷緩存數據是否有效。
(2)即使應用程序終止,只要Cache.Add方法中定義的緩存時間未過期,下次開啟應用程序時,緩存的數據依然存在。而Session緩存只是存在於一次會話中,會話結束後,數據也就失效了。
(3)Session容易丟失,導致數據的不確定性,而Cache不會出現這種情況。
(4)由於Session是每次會話就被載入,所以不適宜存放大量信息,否則會導致伺服器的性能降低。而Cache則主要用來保存大容量信息,如資料庫中的多個表。
(5)Session目前只能保存在內存中,對其性能有影響。
Session:為當前用戶會話提供信息。還提供對可用於存儲信息的會話范圍的緩存的訪問,以及控制如何管理會話的方法。它存儲在伺服器的內存中,因此與在資料庫中存儲和檢索信息相比,它的執行速度更快。與不特定於單個用戶會話的應用程
序狀態不同,會話狀態應用於單個的用戶和會話。因此,應用程序狀態非常適合存儲那些數量少、隨用戶的變化而變化的常用數據。而且由於其不發生伺服器-客戶
端數據傳輸,Session還適合存儲關於用戶的安全數據,如購物車信息。
Session的關鍵特性有:存儲於伺服器內存中,與會話相關,在會話的整個生存期中存在即不會被主動丟棄,不被序列化,不發生伺服器-客戶端數據傳輸。
Cache:它存儲於
伺服器的內存中,允許您自定義如何緩存項以及將它們緩存多長時間。例如,當缺乏系統內存時,緩存會自動移除很少使用的或優先順序較低的項以釋放內存。該技術
也稱為清理,這是緩存確保過期數據不使用寶貴的伺服器資源的方式之一。它不與會話相關,所以它是多會話共享的,因此使用它可以提高網站性能,但是可能泄露
用戶的安全信息,還由於在伺服器缺乏內存時可能會自動移除Cache因此需要在每次獲取數據時檢測該Cache項是否還存在。
Cache的關鍵特性有:存儲於伺服器內存中,與會話無關,根據伺服器內存資源的狀況隨時可能被丟棄,不被序列化,不發生伺服器-客戶端數據傳輸。
Cookie:Cookie 提供了一種在 Web 應用程序中存儲用戶特定信息的方法。例如,當用戶訪問您的站點時,您可以使用 Cookie
存儲用戶首選項或其他信息。當該用戶再次訪問您的網站時,應用程序便可以檢索以前存儲的信息。在開發人員以編程方式設置Cookie時,需要將自己希望保
存的數據序列化為字元串(並且要注意,很多瀏覽器對Cookie有4096位元組的限制)然後進行設置。
Cookie的關鍵特性有:存儲於客戶端硬碟上,與用戶相關,在一定時間內持久化存儲,可以跨瀏覽器共享數據,需要被序列化,發生伺服器-客戶端數據傳輸。
下面這個問題很有啟發性:
最近小組的同事很喜歡用Session做頁面跳轉,具體就是在查詢頁面把查詢結果放到DataTable中,用Session存儲這個dataTable,讀取到數據之後再子頁面做Session清除,這樣對性能有沒有什麼影響?
1、session:session的確是存放在伺服器的內存中(但不是4k上限,具體大小限制應該是伺服器內存),而且同一個sessionid的多個
http請求會排隊,也就是session對於同一個瀏覽器來說是同步的,用不好會極大影響性能。另外,session依賴於客戶端cookie,因為
sessionid是存放在客戶端瀏覽器進程cookie中的,因此不支持cookie的瀏覽器,session也會丟失(session
url重寫可部分解決這個問題,可參考:http://www.sungness.com/archives/48)。因此不建議用。
2、cookie,也不建議存放datatable這樣的「大數據」。因為cookie不僅有4k上限,並且不是「純存放在客戶端」這么簡單,要知道
cookie的值在每次web頁面請求往返的過程中都是要附帶在http頭中的,如果太大會佔用伺服器和客戶端之間的網路帶寬(雖然只是4k,但在線人多
了可就是4k * n了)。對於b/s結構的應用來說,網路帶寬是性能最主要的瓶頸之一!另外,對於datatbale轉換成json字元串再存入
cookie,伺服器CPU也會消耗。最可怕的是,一但你的cookie忘記刪除了,那麼在其有效期和作用域內,用戶訪問你的所有頁面時都將攜帶這個4K
大小的http頭,那就悲劇了。10000在線人數,4千兆網卡也不夠你花的。
3、資料庫連接,每次保存查詢語句然後再查詢的方式不錯,不過看你的查詢復雜度了,如果很費時的查詢,這樣調用也是不可取的。內存和cpu的矛盾你要根據
實際情況作出選擇。對於具有連接池的應用來說,一次連接數據的成本並不高,經過測試差不多=10次調用取當前系統時間函數。但查詢語句的復雜度就沒譜了。
另外,如果並發人數很多的情況下,頻繁佔用資料庫連接,會導致連接池沒有可用連接了,那就又悲劇了。此時就不是一次連接的成本,系統整體性能將毀滅性的下
降,反應遲鈍。
4、cache:一個不錯的選擇,不過它可同樣是佔用伺服器內存哦,只是比session多了一些靈活性。不過我也不建議你用於存放傳遞參數的地方。要知
道session就算內存滿了也不會丟失你的參數值(會拋異常),可cache可不是,它會直接刪掉你的參數值,甚至內存極度不足時都不會讓你進去(也不
會報錯)。換句話說,可能上一行代碼剛存進去,下一行代碼去讀就丟了。很可怕吧~
5、form表單:最為提倡的方式,http協議中原本頁面間傳值的方法就是這樣的,只是有時不太方便,能用之則用之。
6、自定義存儲機制:如果你對性能要求很苛刻,或者非要精益求精的話。那麼還是自己寫一個存儲機制吧。例如我自己就是寫了自己的XSession對象,它
的用法與session使用類似,但是存儲機制都是我自己封裝的,既有cache的優點、又有session的優點,還有資料庫的優點、性能看你寫的演算法
了、而且具有更大的使用靈活性。缺點就是需要你自己coding.
Ⅹ 在java中如何用cookies保存數據
一、java保存寫入Cookie
JSP程序片段如下:
//保存寫入Cookie
<%
String cookieName="Sender";
Cookie cookie=new Cookie(cookieName, "Test_Content");
cookie.setMaxAge(10); //存活期為10秒
response.addCookie(cookie);
%>
二、讀取出Cookie
Cookie文件創建好後,自然還需要用戶把它讀出來,代碼片段如下:
<%
Cookie cookies[]=request.getCookies(); //讀出用戶硬碟上的Cookie,並將所有的Cookie放到一個cookie對象數組裡面
Cookie sCookie=null;
String svalue=null;
String sname=null;
for(int i=0;i<cookies.length-1;i++{ //用一個循環語句遍歷剛才建立的Cookie對象數組
sCookie=cookies; //取出數組中的一個Cookie對象
sname=sCookie.getName(); //取得這個Cookie的名字
svalue=sCookie.getValue(); //取得這個Cookie的內容
%>
<%
}
%>
name value
<%=name%> <%=svalue%>