emu in blogjava

            BlogJava :: 首頁 :: 新隨筆 :: 聯系 :: 聚合  :: 管理 ::
            171 隨筆 :: 103 文章 :: 1052 評論 :: 2 Trackbacks
          很多時候我們做web開發往cookie里面存數據,只是為了在不同的網頁之間跳轉的時候可以共享數據,但是cookie里面的每個數據不管是否需要都會在每個同域的http請求中被發送往服務器,包括每個頁面、圖片、css、腳本或者ajax的的請求,這就無形中占用了多余的帶寬。更糟糕的是,一個網頁的cookie本來也只有有限的4k空間,一旦不小心寫入的cookie超過了限制,就會造成原來有用的cookie丟失,這樣造成的bug非常難以追查。

          因此我們在IE下面經常使用userdata來保存共享數據。但是在firefox下面卻一直缺乏對應的特性。

          今天在看firefox 2.0的?的時候,驚奇的發現一個新特性叫做:
          Support for
          client-side session and persistent storage
          趕緊試驗了一下,firefox2.0果然支持這個特性了。雖然還只能在session生命周期內使用(而不像ie的userdata可以指定有效時間),但是總算解決了cookie占用的問題了。

          以前曾經寫過一個只支持ie的userdata管理器,現在可以升級了:

          <!DOCTYPE?HTML?PUBLIC?"-//W3C//DTD?HTML?4.0?Transitional//EN">
          <HTML>
          <HEAD>
          <TITLE>?UserData?manager?</TITLE>
          <META?NAME="Generator"?CONTENT="EditPlus">
          <META?NAME="Author"?CONTENT="emu">
          <META?NAME="Keywords"?CONTENT="IE?USER?DATA?manager">
          <META?NAME="Description"?CONTENT="UserData?manager">
          </HEAD>
          <BODY>
          <SCRIPT?LANGUAGE="JavaScript">
          <!--
          var?isIE?=?!!document.all;
          if(isIE)
          document.documentElement.addBehavior(
          "#default#userdata");
          function??saveUserData(key,?value){
          ????
          var?ex;?
          ????
          if(isIE){
          ????????
          with(document.documentElement)try?{
          ????????????load(key);
          ????????????setAttribute(
          "value",?value);
          ????????????save(key);
          ????????????
          return??getAttribute("value");
          ????????}
          catch?(ex){
          ????????????alert(ex.message)
          ????????}
          ????}
          else?if(window.sessionStorage){//for?firefox?2.0+
          ????????try{
          ????????????sessionStorage.setItem(key,value)
          ????????}
          catch?(ex){
          ????????????alert(ex);
          ????????}
          ????}
          else{
          ????????alert(
          "當前瀏覽器不支持userdata或者sessionStorage特性")
          ????}
          }

          function?loadUserData(key){
          ????
          var?ex;?
          ????
          if(isIE){
          ????????
          with(document.documentElement)try{
          ????????????load(key);
          ????????????
          return?getAttribute("value");
          ????????}
          catch?(ex){
          ????????????alert(ex.message);
          return?null;
          ????????}
          ????}
          else?if(window.sessionStorage){//for?firefox?2.0+
          ????????try{
          ????????????
          return?sessionStorage.getItem(key)
          ????????}
          catch?(ex){
          ????????????alert(ex)
          ????????}
          ????}
          else{
          ????????alert(
          "當前瀏覽器不支持userdata或者sessionStorage特性")
          ????}
          }
          function??deleteUserData(key){
          ????
          var?ex;?
          ????
          if(isIE){
          ????????
          with(document.documentElement)try{
          ????????????load(key);
          ????????????expires?
          =?new?Date(315532799000).toUTCString();
          ????????????save(key);
          ????????}
          ????????
          catch?(ex){
          ????????????alert(ex.message);
          ????????}
          ????}
          else?if(window.sessionStorage){//for?firefox?2.0+
          ????????try{
          ????????????sessionStorage.removeItem(key)
          ????????}
          catch?(ex){
          ????????????alert(ex)
          ????????}
          ????}
          else{
          ????????alert(
          "當前瀏覽器不支持userdata或者sessionStorage特性")
          ????}
          }?

          saveUserData(
          "emu","hello?world?!")
          alert(loadUserData(
          "emu"))
          deleteUserData(
          "emu")
          alert(loadUserData(
          "emu"))
          //-->
          </SCRIPT>
          </BODY>
          </HTML>

          這個特性不能在本地網頁上試驗,必須把頁面用某個服務器(apache或者iis都可以)發布后用firefox訪問。
          posted on 2006-10-04 15:13 emu 閱讀(9186) 評論(20)  編輯  收藏

          評論

          # re: 終于盼到了,firefox支持sessionStorage了 2006-10-04 19:08 pear
          原來還有 userdata這個東東,算是長見識了。不說還不知道IE有這個東西。

          問下樓主,你一般用userdata保存些什么東西??  回復  更多評論
            

          # re: 終于盼到了,firefox支持sessionStorage了 2006-10-04 20:34 冰川
          不管啦,支持!  回復  更多評論
            

          # re: 終于盼到了,firefox支持sessionStorage了 2006-10-04 21:02 emu
          @pear
          userdata可以在客戶端保存多達64k的數據,可以用來保存用戶信息、操作歷史、購物車,各種各樣的數據。在關掉瀏覽器后下次在此訪問此網頁的時候仍可以訪問。  回復  更多評論
            

          # re: 終于盼到了,firefox支持sessionStorage了 2006-10-05 19:21 Alex
          userdata真是好東西 :)  回復  更多評論
            

          # re: 終于盼到了,firefox支持sessionStorage了 2006-10-07 00:18 葉子
          opera下有點問題  回復  更多評論
            

          # re: 終于盼到了,firefox支持sessionStorage了 2006-10-13 17:06 Flyingis
          一般的網上購物網站都有類似userdata這個功能,比如新蛋、amazon等。

          但是我發現在新蛋www.newegg.com.cn網站,使用Firefox 1.5.0.7在不注冊情況下同樣可以保存我的瀏覽記錄,不知道這是怎么實現的?  回復  更多評論
            

          # re: 終于盼到了,firefox支持sessionStorage了 2006-10-14 17:16 emu
          新蛋的做法不是太有技術含量了。關鍵就在它寫的 NeweggCookie 里面。每把一樣東西放進購物車,NeweggCookie就會長一截(在&符號前面一段會增長)。這個懂一點點web開發的都會了。  回復  更多評論
            

          # re: 終于盼到了,firefox支持sessionStorage了 2006-10-17 15:58 Flyingis
          @emu
          慚愧啊,自己的確沒有用到過。  回復  更多評論
            

          # ff 2.0的最新 release notes 2006-10-24 13:27 firefox
          http://en-us.www.mozilla.com/en-US/firefox/2.0/releasenotes/  回復  更多評論
            

          # re: 終于盼到了,firefox支持sessionStorage了 2007-06-25 18:16 TX同學
          用了這個東西在用戶刷新時保存數據,但是不知道怎么設置讓IE在關閉瀏覽器后失效,能說明一下么?  回復  更多評論
            

          # re: 終于盼到了,firefox支持sessionStorage了 2007-06-27 11:22 emu
          一般我都是設置一個臨時cookie來監視ie關閉。在下次打開的時候如果監測不到cookie就清空數據,再重設上cookie。  回復  更多評論
            

          # re: 終于盼到了,firefox支持sessionStorage了[未登錄] 2007-06-28 10:33 andrew
          謝謝stone  回復  更多評論
            

          # re: 終于盼到了,firefox支持sessionStorage了 2007-07-27 17:53 瀟灑
          哈哈…… 我也是以前寫了個只支持IE的cache類,現在想支持 FF ……
          一下就google到emu老大你的窩了…… 謝了!~  回復  更多評論
            

          # re: 終于盼到了,firefox支持sessionStorage了 2008-01-09 09:41 在線代理
          這個太強了,一定要訂購大大的rss。
          學習了userdata。  回復  更多評論
            

          # re: 終于盼到了,firefox支持sessionStorage了[未登錄] 2008-04-15 16:29 阿福
          在FF在關閉下重新打開,數據還是會丟失,在IE下倒不錯  回復  更多評論
            

          # re: 終于盼到了,firefox支持sessionStorage了[未登錄] 2008-05-03 10:17 閑耘
          學習,支持。  回復  更多評論
            

          # re: 終于盼到了,firefox支持sessionStorage了 2009-02-26 16:38 小蔡
          長見識了  回復  更多評論
            

          # re: 終于盼到了,firefox支持sessionStorage了[未登錄] 2009-10-07 10:54 Robin
          如果僅僅為了session范圍的數據,還不如用服務器端程序的session存儲,省下不少問題~
          電子商務的站點都是這么實現購物車的吧~  回復  更多評論
            

          # re: 終于盼到了,firefox支持sessionStorage了 2009-10-12 09:24 emu
          @Robin
          呵呵,是省不少問題,但是多出來的不少問題和成本要等你做大系統的時候才會看到了  回復  更多評論
            

          # re: 終于盼到了,firefox支持sessionStorage了 2009-12-29 23:14 jacklau
          stone,那sessionStorage是存儲在哪里的呢?內存?  回復  更多評論
            


          只有注冊用戶登錄后才能發表評論。


          網站導航:
           
          主站蜘蛛池模板: 六安市| 桦南县| 鄂尔多斯市| 克什克腾旗| 抚宁县| 大港区| 神农架林区| 花垣县| 彰化市| 峨边| 山东| 香格里拉县| 昭觉县| 奉化市| 客服| 大渡口区| 卢氏县| 兰西县| 聂拉木县| 抚州市| 泽库县| 霞浦县| 龙里县| 鄂托克前旗| 贵德县| 蕲春县| 高州市| 石屏县| 海淀区| 四子王旗| 神农架林区| 柯坪县| 盐山县| 阿拉尔市| 星子县| 南城县| 乡宁县| 库尔勒市| 蒙自县| 北流市| 汤阴县|