溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

Session如何在Asp與Asp.Net中實(shí)現(xiàn)共享

發(fā)布時(shí)間:2020-12-09 15:36:50 來(lái)源:億速云 閱讀:265 作者:Leah 欄目:開發(fā)技術(shù)

本篇文章給大家分享的是有關(guān)Session如何在Asp與Asp.Net中實(shí)現(xiàn)共享,小編覺(jué)得挺實(shí)用的,因此分享給大家學(xué)習(xí),希望大家閱讀完這篇文章后可以有所收獲,話不多說(shuō),跟著小編一起來(lái)看看吧。

<iframe align="top" marginwidth="0" marginheight="0" src="http://www.zealware.com/46860.html" frameborder="0" width="468" scrolling="no" height="60"></iframe>

在.net中,Session的存儲(chǔ)機(jī)制已經(jīng)與Asp的存儲(chǔ)機(jī)制不一樣,雖然可以在同一個(gè)IIS下同時(shí)運(yùn)行asp與aspx,但是它們之間不能傳遞Session。
之前大批系統(tǒng)應(yīng)用到了asp,在升級(jí)過(guò)程中,如果完全拋棄asp來(lái)重寫,一來(lái)工作量太大,二來(lái)以前的成果不能保存下來(lái)。
所以微軟提出了一個(gè)Session共享的解決方案,只是此文檔光說(shuō)明原理,并沒(méi)有說(shuō)具體的操作步驟,由此,我撰文描述過(guò)程。

簡(jiǎn)單說(shuō)明原理,asp與asp.net之間的Session統(tǒng)一存儲(chǔ)在數(shù)據(jù)庫(kù)中來(lái)實(shí)現(xiàn)共享

1、創(chuàng)建數(shù)據(jù)表
打開SQL Server查詢分析器,運(yùn)行以下腳本來(lái)創(chuàng)建數(shù)據(jù)表,數(shù)據(jù)表名為SessionState

if exists (select * from sysobjects where id = object_id(N'[dbo].[SessionState]') and OBJECTPROPERTY(id, N'IsUserTable') = 1) 
drop table [dbo].[SessionState] 
GO 

create TABLE [dbo].[SessionState] ( 
[ID] uniqueidentifier NOT NULL , 
[Data] [image] NOT NULL , 
[Last_Accessed] [datetime] NOT NULL 
) ON [PRIMARY] TEXTIMAGE_ON [PRIMARY] 
GO 

alter TABLE [dbo].[SessionState] WITH NOCHECK ADD 
CONSTRAINT [PK_SessionState] PRIMARY KEY NONCLUSTERED 
( 
[ID] 
) ON [PRIMARY] 
GO

2、下載以下文件 Session.rar

將文件解壓后,將產(chǎn)生4個(gè)文件,分別作如下操作。
復(fù)制 global.asa 到系統(tǒng)根目錄下,并打開文件,修改Application("SessionDSN") 為合適的數(shù)據(jù)庫(kù)鏈接字符串,如果系統(tǒng)本身已經(jīng)有了global.asa,則在此文件中添加如下Application:
Application("SessionDSN") = "initial catalog=SqlServerName;persist security info=False;user id=sa;password=****;packet size=4096"
在系統(tǒng)的 Web.config 文件中,添加此項(xiàng)
<add key="SessionDSN" value="data source=SqlServerName;initial catalog=SessionDemoDb;persist security info=False;user id=SessionDemoDbUser;password=****;packet size=4096"></add>
并將其值修改為合適的數(shù)據(jù)庫(kù)鏈接。
將另外兩個(gè)dll文件復(fù)制到系統(tǒng)目錄下(或其他合適目錄)

3、關(guān)閉IIS中Asp的Session選項(xiàng)
打開IIS,選擇站點(diǎn),依次選擇屬性 -> 主目錄 -> 配置 -> 應(yīng)用程序選項(xiàng),將啟用會(huì)話狀況前的復(fù)選勾去除。如下圖:
screen.width-350)this.width=screen.width-350" border=0>

4、安裝SessionUtility.dll
首先找到 gacutil.exe 文件,一般情況下在 Microsoft Visual Studio .NET 2003\SDK\v1.1\Bin 目錄下
在命令提示符窗口中,執(zhí)行 gacutil /i SessionUtility.dll,(如果執(zhí)行失敗,請(qǐng)將這兩個(gè)文件的路徑都寫全了)

5、注冊(cè)SessionUtility.dll為Com對(duì)象
同樣,要找到 regasm.exe 文件,一般情況下在 WINNT\Microsoft.NET\Framework\v1.1.4322 目錄下
在命令提示符窗口中,執(zhí)行 regasm.exe SessionUtility.dll /tlb:SessionUtility.tlb,(如果執(zhí)行失敗,請(qǐng)將這兩個(gè)文件的路徑都寫全了)
這樣就會(huì)產(chǎn)生出一個(gè)tlb文件,可當(dāng)做普通的Com組件來(lái)調(diào)用。

6、注冊(cè)SessionManager.dll
這個(gè)很簡(jiǎn)單了,在命令提示符窗口中,執(zhí)行regsvr32 SessionManager.dll

7、如果是NTFS格式的系統(tǒng),請(qǐng)找到 SessionMgr.dll,右鍵點(diǎn)擊,屬性,將IUSR_<machine_name>權(quán)限設(shè)置為可讀和可執(zhí)行。 至此,我們已經(jīng)可以實(shí)現(xiàn)了Asp與Asp.net之間Session共享了,那么怎么去用 在Asp中,我們要如下使用: <br>頁(yè)面開始端 <br>Dim Session <br>Set Session = Server.createObject("SessionMgr.Session2") <br>Session("UserID") = ... <br>... <br>... <br>... <br>頁(yè)面結(jié)束端 <br>Set Session = Nothing '記得一定要釋放哦 而在Asp.net中,我們要如下使用: <br>首先,我們要添加對(duì)SessionUtility的引用 <br>然后,編碼時(shí),原來(lái)是這樣的繼承 public class WebForm1 : System.Web.UI.Page,修改為public class WebForm1 : MSDN.SessionPage <br>這樣在編碼過(guò)程中就可以使用Session("UserID")這樣的形式了。 注意:雖然Session實(shí)現(xiàn)了共享,但是Session的使用語(yǔ)法,相對(duì)于.net中新增的部分,就沒(méi)有實(shí)現(xiàn),畢竟要照顧asp <br>譬如Session.Remove,就不能用了。<p id="TBPingURL">Trackback: http://tb.blog.csdn.net/TrackBack.aspx&#63;PostId=1621435</p> <br></machine_name>

以上就是Session如何在Asp與Asp.Net中實(shí)現(xiàn)共享,小編相信有部分知識(shí)點(diǎn)可能是我們?nèi)粘9ぷ鲿?huì)見到或用到的。希望你能通過(guò)這篇文章學(xué)到更多知識(shí)。更多詳情敬請(qǐng)關(guān)注億速云行業(yè)資訊頻道。

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI