Asp.Net中Session詳解

懂得ASP/ASP.NET編程

  了解ASP/ASP.NET的Session模型

  了解ASP.NET Web應用程序模型

  了解ASP.NET Web應用程序配置文件Web.config的作用、意義及使用方法

  了解Internet Information Services(以下間稱IIS)的基本使用方法

  了解如何在Microsoft SQL Server中創建壹個數據庫。

  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成為了壹個更加強大的功能。

  Web.config文件間介

  有的ASP.NET程序員說:Web.config文件?我從來沒有聽說過啊,可是我寫的程序不是也能很正常的運轉嗎?是的,妳說得沒錯,沒有Web.config文件程序是可以正常運行的。但是,如果妳做了壹個大型的網站,需要對整個網站做壹些整體配置,例如整個網站的頁面使用何種語言編寫的、網站的安全認證模式、Session信息存儲方式等,這時妳就需要使用Web.config文件了。雖然Web.config文件中的某些選項是可以通過IIS配置的,但是如果在Web.config中也有相應的設置就會覆蓋掉IIS中的配置。而且,Web.config文件的最大的便利之處就是可以在ASP.NET頁面中通過調用System.web名字空間訪問Web.config中的設置。

  Web.config有兩種,分別是服務器配置文件和Web應用程序配置文件,他們都名為Web.config。在這個配置文件中會保存當前IIS服務器中網頁的使用哪種語言編寫的、應用程序安全認證模式、Session信息存儲方式的壹系列信息。這些信息是使用XML語法保存的,如果想對其編輯,使用文本編輯器就行了。

  其中服務器配置文件會對IIS服務器下所有的站點中的所有應用程序起作用。在.NET Framework 1.0中,服務器的Web.config文件是存在:      \WinNT\Microsoft.NET\Framework\v1.0.3705中的。

  而Web應用程序配置文件Web.config則保存在各個Web應用程序中。例如:當前網站的根目錄\Inetpub\wwwroot,而當前的Web應用程序為MyApplication,則Web應用程序根目錄就應為:\Inetpub\wwwroot\MyApplication。如果妳的網站有且只有壹個Web應用程序,壹般說來應用程序的根目錄就是\Inetpub\wwwroot。如果想添加壹個Web應用程序,在IIS中添加壹個具有應用程序起始點的虛擬目錄就行了。這個目錄下的文件及目錄將被視為壹個Web應用程序。但是,這洋通過IIS添加Web應用程序是不會為妳生成Web.config文件的。如果想創建壹個帶有Web.config文件的Web應用程序,需要使用Visual Studio.NET,新建壹個Web應用程序項目。

  Web應用程序的配置文件Web.config是可選的,可有可無。如果沒有,每個Web應用程序會使用服務器的Web.config配置文件。如果有,則會覆蓋服務器Web.config配置文件中相應的值。

  在ASP.NET中,Web.config修改保存後會自動立刻成效,不用再像ASP中的配置文件修改後需要重新啟動Web應用程序才能生效了。

  Web.config文件中的Session配置信息 :

  打開某個應用程序的配置文件Web.config後,我們會發現以下這段:

  這壹段就是配置應用程序是如何存儲Session信息的了。我們以下的各種操作主要是針對這壹段配置展開。讓我們先看看這壹段配置中所包含的內容的意思。sessionState節點的語法是這洋的: 必須有的屬性是 屬性 選項 描述 mode 設置將Session信息存儲到哪裏 Off 設置為不使用Session功能 InProc 設置為將Session存儲在進程內,就是ASP中的存儲方式,這是默認值。 StateServer 設置為將Session存儲在獨立的狀態服務中。 SQLServer 設置將Session存儲在SQL Server中。

  可選的屬性是: 屬性 選項 描述 cookieless 設置客護端的Session信息存儲到哪裏 ture 使用Cookieless模式 false 使用Cookie模式,這是默認值。 timeout 設置經過多少分鐘後服務器自動放棄Session信息。默認為20分鐘 stateConnectionString 設置將Session信息存儲在狀態服務中時使用的服務器名稱和端口號,例如:”tcpip=127.0.0.1:42424”。當mode的值是StateServer是,這個屬性是必需的。

  sqlConnectionString 設置與SQL Server連接時的連接字符串。

  例如”data source=localhost;Integrated Security=SSPI;Initial Catalog=northwind”。當mode的值是SQLServer時,這個屬性是必需的。 stateNetworkTimeout 設置當使用StateServer模式存儲Session狀態時,經過多少秒空閑後,斷開Web服務器與存儲狀態信息的服務器的TCP/IP連接的。默認值是10秒鐘。

  ASP.NET中客護端Session狀態的存儲:

  在我們上面的Session模型間介中,大家可以發現Session狀態應該存儲在兩個地方,分別是客護端和服務器端。客護端只負責保存相應網站的SessionID,而其他的Session信息則保存在服務器端。在ASP中,客護端的SessionID實際是以Cookie的形式存儲的。如果用護在瀏覽器的設置中選擇了禁用Cookie,那末他也就無法享受Session的便利之處了,甚至造成不能訪問某些網站。為了解抉以上問題,在ASP.NET中客護端的Session信息存儲方式分為:Cookie和Cookieless兩種。   ASP.NET中,默認狀態下,在客護端還是使用Cookie存儲Session信息的。

  如果我們想在客護端使用Cookieless的方式存儲Session信息的方法如下:

  找到當前Web應用程序的根目錄,打開Web.Config文件,找到如下段落:

  這段話中的cookieless=”false”改為:cookieless=”true”,這洋,客護端的Session信息就不再使用Cookie存儲了,而是將其通過URL存儲。關閉當前的IE,打開壹個新IE,重新訪問剛才的Web應用程序,就會看到類似下面的洋子:

  其中,http://localhost/MyTestApplication/(ulqsek45heu3ic2a5zgdl245)/default.aspx中黑體標出的就是客護端的Session ID。註意,這段信息是由IIS自動加上的,不會影響以前正常的連接。 ASP.NET中服務器端Session狀態的存儲 準備工作

  為了您能更好的體驗到實驗現象,您可以建立壹個叫做SessionState.aspx的頁面,然後把以下這些代碼添加到中。

  這個SessionState.aspx的頁面可以用來測試在當前的服務器上是否丟失了Session信息。

  將服務器Session信息存儲在進程中讓我們來回到Web.config文件的剛才那段段落中:

  當mode的值是InProc時,說明服務器正在使用這種模式。

  這種方式和以前ASP中的模式壹洋,就是服務器將Session信息存儲在IIS進程中。當IIS關閉、重起後,這些信息都會丟失。但是這種模式也有自己最大好處,就是性能最高。應為所有的Session信息都存儲在了IIS的進程中,所以IIS能夠很快的訪問到這些信息,這種模式的性能比進程外存儲Session信息或是在SQL Server中存儲Session信息都要快上很多。這種模式也是ASP.NET的默認方式。

  好了,現在讓我們做個試驗。打開剛才的SessionState.aspx頁面,隨便輸入壹些字符,使其存儲在Session中。然後,讓我們讓IIS重起。註意,並不是使當前的站點停止再開始,而是在IIS中本機的機器名的節點上點擊鼠標右鍵,選擇重新啟動IIS。(想當初使用NT4時,重新啟動IIS必須要重新啟動計算機才行,微軟真是@#$%^&)返回到SessionState.aspx頁面中,檢查剛才的Session信息,發現信息已經丟失了。

  將服務器Session信息存儲在進程外

  首先,讓我們來打開管理工具->服務,找到名為:ASP.NET State Service的服務,啟動它。實際上,這個服務就是啟動壹個要保存Session信息的進程。啟動這個服務後,妳可以從Windows任務管理器->進程中看到壹個名為aspnet_state.exe的進程,這個就是我們保存Session信息的進程。

  然後,回到Web.config文件中上述的段落中,將mode的值改為StateServer。保存文件後的重新打開壹個IE,打開SessionState.aspx頁面,保存壹些信息到Session中。這時,讓我們重起IIS,再回到SessionState.aspx頁面中查看剛才的Session信息,發現沒有丟失。

  實際上,這種將Session信息存儲在進程外的方式不光指可以將信息存儲在本機的進程外,還可以將Session信息存儲在其他的服務器的進程中。這時,不光需要將mode的值改為StateServer,還需要在stateConnectionString中配置相應的慘數。例如妳的計算妳是192.168.0.1,妳想把Session存儲在IP為192.168.0.2的計算機的進程中,就需要設置成這洋:stateConnectionString=”tcpip=192.168.0.2:42424″。當然,不要忘記在192.168.0.2的計算機中裝上.NET Framework,並且啟動ASP.NET State Services服務。

  將服務器Session信息存儲在SQL Server中

  首先,還是讓我們來做壹些準備工作。啟動SQL Server和SQL Server代理服務。在SQL Server中執行壹個叫做InstallSqlState.sql的腳本文件。這個腳本文件將在SQL Server中創建壹個用來專門存儲Session信息的數據庫,及壹個維護Session信息數據庫的SQL Server代理作業。我們可以在以下路徑中找到那個文件: [system drive]\winnt\Microsoft.NET\Framework\[version]\   然後打開查詢分析器,連接到SQL Server服務器,打開剛才的那個文件並且執行。稍等片刻,數據庫及作業就建立好了。這時,妳可以打開企業管理器,看到新增了壹個叫ASPState的數據庫。但是這個數據庫中只是些存儲過程,沒有用護表。實際上Session信息是存儲在了tempdb數據庫的ASPStateTempSessions表中的,另外壹個ASPStateTempApplications表存儲了ASP中Application對象信息。這兩個表也是剛才的那個腳本建立的。另外查看管理->SQL Server代理->作業,發現也多了壹個叫做ASPState_Job_DeleteExpiredSessions的作業,這個作業實際上就是每分鐘去ASPStateTempSessions表中刪除過期的Session信息的。

  接著,我們返回到Web.config文件,修改mode的值改為SQLServer。註意,還要同時修改sqlConnectionString的值,格式為:

     sqlConnectionString=”data source=localhost; Integrated Security=SSPI;”

  其中data source是指SQL Server服務器的IP地址,如果SQL Server與IIS是壹臺機子,寫127.0.0.1就行了。Integrated Security=SSPI的意思是使用Windows集成身份驗證,這洋,訪問數據庫將以ASP.NET的身份進行,通過如此配置,能夠獲得比使用userid=sa;password=口令的SQL Server驗證方式更好的安全性。當然,如果SQL Server運行於另壹臺計算機上,妳可能會需要通過Active Directory域的方式來維護兩邊驗證的壹致性。

淺讀家用型交換機使用小技巧

在現代網絡設計中,通過使用以太網交換機可顯著地提高整個用戶網絡的應用性能,現在很多家用型交換機的速度都達到了100Mbps,已經能夠滿足大部分用戶的需求了。

  為此家用型交換機也愈來愈受到更多網絡用戶的青睞。交換機設備除了在速度上給網絡用戶帶來優勢外,還可以比傳統的網絡共享設備提供更多的功能。隨著交換機市場競爭愈趨激烈,交換設備的價格也更能為用戶所接受,目前家用型交換機已經迅速代替集線器,成為用戶構造網絡的首選產品。

  交換機與集線器的區別為了更深壹步認識交換機,我們有必要先了解交換機與集線器的區別:如果我們把集線器看成是壹條內置的以太網總線的話,家用型交換機則可以被視為多條總線——交換矩陣互連。

  從技術上來講,交換機把每壹個端口都掛在壹條帶寬很高的背板總線上(至少比端口帶寬高出壹個數量級),並與壹個交換機相連,由端口丟進來的封裝數據包經背板總線進入家用型交換機。並通過直通轉發和存儲並轉發兩種方式進行交換。

  另外,從使用效果上講,交換機的性價比更高。以前家用型交換機價格較高是我們退而求次選擇集線器的主要原因。隨著近幾年交換技術的不斷發展,以太網交換機的價格急劇下降,時至今日,交換機的性價比已遠遠超過集線器。

  選購市場上的家用型交換機價格,從百元、數百元到千元、數千元不等,而且品牌眾多。對於普通的家庭用戶來說,SOHO交換機是比較好的選擇。SOHO交換機幾乎是清壹色的桌面式家用型交換機。

  它們的尺寸大小不壹,通常提供5~8個10/100Mbps自適應端口。與壹般中高端交換機相比,SOHO交換機通常采用不可進行網絡管理,不能對它進行任何管理和設置,接入的計算機數量非常有限,但是價格非常便宜,適用於簡單的網絡環境的家庭網絡使用。下面筆者說跟大家介紹幾點選購時的註意事項。

  端口類型通常交換機端口數量越多,交換機價格越高,可以連接的計算機數量越多。對於家庭用戶而言,選擇5口或者8口SOHO交換機就足夠了。交換機的端口類型壹般包括N個RJ-45端口,以及至少壹個的UPLink端口。另外,必須要註意端口是否支持MDI/MDIX,通過該功能可以在級聯交換設備是自動進行適當的線序連接,無需手工配置線序。

  傳輸速率目前主流的家用型交換機傳輸速度還是100Mbps,這樣的速率基本可以滿足家庭需要。雖然近年來千兆網絡技術已經快速發展,但是並不實用,在市場上,還是以10/100Mbps自適應交換機為主。不過考慮到未來網絡升級的需要,可以選擇10/100/1000Mbps自適應或者100/1000Mbps自適應千兆交換機,不過價格較高。

  價格無疑是廣大用戶在選購交換機時考慮最多的問題,目前,適合家用或小型辦公網絡使用的家用型交換機價格與即將“淘汰”的集線器(Hub)價格已經相差無幾,比如5口的10/100Mbps自適應家用型交換機價格大致在100~300元(國外的產品除外)。

  壹般端口數量越多、速率越大、背板帶寬越高、網管功能越強大的交換機產品的價格也越高。對於家庭來說,8口的SOHO交換機已經足夠使用了。品牌在國內市場上,低端交換機產品涵蓋了從3Com等國外網絡巨頭到D-Link(友訊網絡)、TP-Link、頂星等眾多國內品牌。在選購家用型交換機時,要註意產品供應商的品牌知名度、用戶的口碑、產品的售後服務以及質保情況。

  外形SOHO交換機的外殼壹般采用塑殼或鐵殼包裝,價格差別不大;外形通常采用小巧、迷妳型,大家可以根據自己的喜好來選擇,交換機的全雙工是指交換機在發送數據的同時也能夠接收數據,兩者同步進行,這好像我們平時打電話壹樣,說話的同時也能夠聽到對方的聲音。

  目前的家用型交換機都支持全雙工。全雙工的好處在於遲延小,速度快。提到全雙工,就不能不提與之密切對應的另壹個概念,那就是“半雙工”,所謂半雙工就是指壹個時間段內只有壹個動作發生。

  舉個簡單例子,壹條窄窄的馬路,同時只能有壹輛車通過,當目前有兩量車對開,這種情況下就只能壹輛先過,等到頭兒後另壹輛再開,這個例子就形象的說明了半雙工的原理。早期的對講機、以及早期集線器等設備都是實行半雙工的產品。

  隨著技術的不斷進步,半雙工會逐漸退出歷史舞臺,從廣義上來看,網絡交換機分為兩種:廣域網交換機和局域網交換機。廣域網交換機主要應用於電信領域,提供通信用的基礎平臺。而局域網交換機則應用於局域網絡,用於連接終端設備,如PC機及網絡打印機等。

  從傳輸介質和傳輸速度上可分為以太網交換機、快速以太網交換機、千兆以太網交換機、FDDI交換機、ATM交換機和令牌環交換機等。從規模應用上又可分為企業級交換機、部門級交換機和工作組交換機等。

  各廠商劃分的尺度並不是完全壹致的,壹般來講,企業級交換機都是機架式,部門級交換機可以是機架式(插槽數較少),也可以是固定配置式,而工作組級交換機為固定配置式(功能較為簡單)。

  另壹方面,從應用的規模來看,作為骨幹交換機時,支持500個信息點以上大型企業應用的交換機為企業級交換機,支持300個信息點以下中型企業的交換機為部門級交換機,而支持100個信息點以內的交換機為工作組級交換機。本文所介紹的交換機指的是局域網交換機。

Linux文件rwx屬性的含義

Linux上的文件以.開頭的文件被系統視為隱藏文件,僅用ls命令是看不到他們的,而用ls -a除了顯示 壹般文件名外,連隱藏文件也會顯示出來。

  ls -l(這個參數是字母L的小寫,不是數字1)

  這個命令可以使用長格式顯示文件內容,如果需要察看更詳細的文件資料,就要用到ls -l這個指令。例如我在某個目錄下鍵入ls -l可能會顯示如下信息(壹共7個欄位):

  文件屬性   文件數 擁有者 所屬的group 文件大小 建檔日期     文件名

  drwx——   2           Guest        users         1024      Nov 21 21:05 Mail

  -rwx–x–x 1 root root 89080 Nov 7 22:41 tar*

  -rwxr-xr-x 1 root bin 5013 Aug 15 9:32 uname*

  lrwxrwxrwx 1 root root 4 Nov 24 19:30 zcat->gzip

  -rwxr-xr-x 1 root bin 308364 Nov 29 7:43 zsh*

  -rwsr-x— 1 root bin 9853 Aug 15 5:46 su*

  第壹個欄位,表示文件的屬性。Linux的文件基本上分為三個屬性:可讀(r),可寫(w),可執行(x)。但是這裏有十個格子可以添(具體程序實現時,實際上是十個bit位)。第壹個小格是特殊表示格,表示目錄或連結文件等等,d表示目錄,例如drwx——;l表示連結文件,如 lrwxrwxrwx;如果是以壹橫”-“表示,則表示這是文件。其余剩下的格子就以每3格為壹個單位。因為Linux是多用戶多任務系統,所以壹個文件可能同時被許多人使用,所以我們壹定要設好每個文件的權限,其文件的權限位置排列順序是(以-rwxr-xr-x為例):

  rwx(Owner)r-x(Group)r-x(Other)

  這個例子表示的權限是:使用者自己可讀,可寫,可執行;同壹組的用戶可讀,不可寫,可執行;其它用戶可讀,不可寫,可執行。另外,有壹些程序屬性的執行部分不是x,而是s,這表示執行這個程序的使用者,臨時可以有和擁有者壹樣權力的身份來執行該程序。壹般出現在系統管理之類的指令或程序,讓使用者執行時,擁有root身份。

  第二個欄位,表示文件個數。如果是文件的話,那這個數目自然是1了,如果是目錄的話,那它的數目就是該目錄中的文件個數了。

  第三個欄位,表示該文件或目錄的擁有者。若使用者目前處於自己的home,那這壹欄大概都是它的賬號名稱。

  第四個欄位,表示所屬的組(group)。每壹個使用者都可以擁有壹個以上的組,不過大部分的使用者應該都只屬於壹個組,只有當系統管理員希望給予某使用者特殊權限時,才可能會給他另壹個組。

  第五欄位,表示文件大小。文件大小用byte來表示,而空目錄壹般都是1024byte,妳當然可以用其它參數使文件顯示的單位不同,如使用ls -k就是用kb萊顯示壹個文件的大小單位,不過壹般我們還是以byte為主。

  第六個欄位,表示創建日期。以”月,日,時間”的格式表示,如Aug 15 5:46表示8月15日早上5:46分。

  第七個欄位,表示文件名。我們可以用ls -a顯示隱藏的文件名。