天天看點

艾偉_轉載:Cookie是什麼?用法是怎樣?與SESSION有什麼差別?(二)

  二session 簡介

  IE中:

  有效的窗品包括

  1.Session對象隻在建立Session對象的視窗中有效。

  2.在建立Session對象的視窗中新開連結的視窗

  無效的視窗包括

  1.直接啟動IE浏覽器的視窗

  2.不是在建立Session對象的視窗中新開連結的視窗

  NetScape中:

  隻要一個視窗有了某個Session對象,則全部視窗對此Session都有效

  Session是什麼呢?簡單來說就是伺服器給用戶端的一個編号。當一台WWW伺服器運作時,可能有若幹個使用者浏覽正在運正在這台伺服器上的網站。當每個使用者首次與這台WWW伺服器建立連接配接時,他就與這個伺服器建立了一個Session,同時伺服器會自動為其配置設定一個SessionID,用以辨別這個使用者的唯一身份。這個SessionID是由WWW伺服器随機産生的一個由24個字元組成的字元串,我們會在下面的實驗中見到它的實際樣子。

  這個唯一的SessionID是有很大的實際意義的。當一個使用者送出了表單時,浏覽器會将使用者的SessionID自動附加在HTTP頭資訊中,(這是浏覽器的自動功能,使用者不會察覺到),當伺服器處理完這個表單後,将結果傳回給SessionID所對應的使用者。試想,如果沒有 SessionID,當有兩個使用者同時進行注冊時,伺服器怎樣才能知道到底是哪個使用者送出了哪個表單呢。當然,SessionID還有很多其他的作用,我們會在後面提及到。

  除了SessionID,在每個Session中還包含很多其他資訊。但是對于編寫ASP或ASP.NET的程式與來說,最有用的還是可以通過通路 ASP/ASP.NET的内置Session對象,為每個使用者存儲各自的資訊。例如我們想了解一下通路我們網站的使用者浏覽了幾個頁面,我們可能在使用者可能通路到每個的頁面中加入:

  通過以下這句話可以讓使用者得知自己浏覽了幾個頁面:

  可能有些有些讀者會問:這個看似像是數組的Session(“..”)是哪裡來的?需要我定義嗎?實際上,這個Session對象是具有ASP解釋能力的的WWW伺服器的内建對象。也就是說ASP的系統中已經給你定義好了這個對象,你隻需要使用就行了。其中Session(“..”)中的..就好像變量名稱,Session(“..”)=$$中的$$就是變量的值了。你隻需要寫上句話,在這個使用者的每個頁面中都可以通路..變量中的值了。

  其實ASP一共内建了7個對象,有Session、Application、Cookie、Response、Request、Server等。在其他的伺服器端腳本語言如JSP、PHP等中也有其類似的對象,隻是叫法或者使用方法上不太一樣。

  ASP Session的功能的缺陷

  目前ASP的開發人員都正在使用Session這一強大的功能,但是在他們使用的過程中卻發現了ASP Session有以下缺陷:

  程序依賴性:ASP Session狀态存于IIS的程序中,也就是inetinfo.exe這個程式。是以當inetinfo.exe程序崩潰時,這些資訊也就丢失。另外,重起或者關閉IIS服務都會造成資訊的丢失。

  Session狀态使用範圍的局限性:剛一個使用者從一個網站通路到另外一個網站時,這些Session資訊并不會随之遷移過去。例如:新浪網站的 WWW伺服器可能不止一個,一個使用者登入之後要去各個頻道浏覽,但是每個頻道都在不同的伺服器上,如果想在這些WWW伺服器共享Session資訊怎麼辦呢?

  Cookie的依賴性:實際上用戶端的Session資訊是存儲與Cookie中的,如果用戶端完全禁用掉了Cookie功能,他也就不能享受到了Session提供的功能了。

  鑒于ASP Session的以上缺陷,微軟的設計者們在設計開發 ASP.NET Session時進行了相應的改進,完全克服了以上缺陷,使得ASP.NET Session成為了一個更加強大的功能。

  三 差別

  Session是存在伺服器端的;而Cookie是存在用戶端的!!

  Session更不需要Cookie來支援和不會受浏覽器端的設定影響,可記錄每個通路者的資訊,獨立在伺服器端,比Cookie安全!

  Session是存在記憶體中的,浏覽器關閉它也就“死”了;Cookie是以檔案方式存在的,可以修改其“存活”時間。