程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> .NET網頁編程 >> .NET實例教程 >> 跨應用程序進行Forms身份驗證詳解

跨應用程序進行Forms身份驗證詳解

編輯:.NET實例教程

先仔細閱讀這段內容:ASP.Net 支持在分布式環境中(跨單個服務器上的多個應用程序或在網絡場中)進行 Forms 身份驗證。
  之前研究過多站點間的Session共享的問題,這裡說下跨應用程序進行 Forms 身份驗證詳細實現方式,此方案的基礎就是“跨應用程序進行 Forms 身份驗證”(幫助可點擊鏈接或是自己直接查找MSDN)。
  在VS2005中建立兩個Web應用程度的項目,兩個項目都添加一個Default.aspx頁面,其中一個項目增加Login.ASPx頁面,實現“Forms 身份驗證”。
  在兩個項目的Default.ASPx.cs代碼頁面添加如下代碼:vIEw plaincopy to clipboardprint?
Response.Write(User.Identity.Name); //輸出當前Form認證後登錄的用戶名 

Response.Write(User.Identity.Name); //輸出當前Form認證後登錄的用戶名  假設兩個項目的訪問地址如下:
  A項目:http://localhost/test/
  B項目(帶登錄):http://localhost:81/
  從上地址可以看出兩個項目處於不同的域名下,即兩個項目處於兩個不同的Web站點
  設置A項目的web.configvIEw plaincopy to clipboardprint?
 <authentication mode="Forms">  
 <!--   
  這裡loginUrl是指向B項目的登錄頁面   
  注意:name、protection、path、validationKey、validation、decryptionKey 和 decryption 屬性必須在所有應用程序中都完全相同   
 -->  
 <forms loginUrl="http:localhost:81/Login.aspx" path="/" protection="All" defaultUrl="http:localhost:81/Default.ASPx" timeout="40" name=".DeESoft">  
 </forms>  
 </authentication>  
 <MachineKey  
 validationKey="C50B3C89CB21F4F1422FF158A5B42D0E8DB8CB5CDA1742572A487D9401E3400267682B202B746511891C1BAF47F8D25C07F6C39A104696DB51F17C529AD3CABE"  
 decryptionKey="8A9BE8FD67AF6979E7D20198CFEA50DD3D3799C77AF2B72F"  
 validation="SHA1" />  
 <authorization>  
 <deny users="?" />  
 </authorization> 

 <authentication mode="Forms">
 <!--
  這裡loginUrl是指向B項目的登錄頁面
  注意:name、protection、path、validationKey、validation、decryptionKey 和 decryption 屬性必須在所有應用程序中都完全相同
 -->
 <forms loginUrl="http:localhost:81/Login.aspx" path="/" protection="All" defaultUrl="http:localhost:81/Default.ASPx" timeout="40" name=".DeESoft">
 </forms>
 </authentication>
 <MachineKey
 validationKey="C50B3C89CB21F4F1422FF158A5B42D0E8DB8CB5CDA1742572A487D9401E3400267682B202B746511891C1BAF47F8D25C07F6C39A104696DB51F17C529AD3CABE"
 decryptionKey="8A9BE8FD67AF6979E7D20198CFEA50DD3D3799C77AF2B72F"
 validation="SHA1" />
 <authorization>
 <deny users="?" />
 </authorization>  再來設置B項目的web.configvIEw plaincopy to clipboardprint?
 <authentication mode="Forms">  
 <!--   
  注意:name、protection、path、validationKey、validation、decryptionKey 和 decryption 屬性必須在所有應用程序中都完全相同   
 -->  
 <forms loginUrl="~/Login.aspx" path="/" protection="All" defaultUrl="~/Default.ASPx" timeout="40" name=".DeESoft">  
 </forms>  
 </authentication>  
 <MachineKey  
 validationKey="C50B3C89CB21F4F1422FF158A5B42D0E8DB8CB5CDA1742572A487D9401E3400267682B202B746511891C1BAF47F8D25C07F6C39A10469
6DB51F17C529AD3CABE"  
 decryptionKey="8A9BE8FD67AF6979E7D20198CFEA50DD3D3799C77AF2B72F"  
 validation="SHA1" />  
 <authorization>  
 <deny users="?" />  
 </authorization> 

 <authentication mode="Forms">
 <!--
  注意:name、protection、path、validationKey、validation、decryptionKey 和 decryption 屬性必須在所有應用程序中都完全相同
 -->
 <forms loginUrl="~/Login.aspx" path="/" protection="All" defaultUrl="~/Default.ASPx" timeout="40" name=".DeESoft">
 </forms>
 </authentication>
 <MachineKey
 validationKey="C50B3C89CB21F4F1422FF158A5B42D0E8DB8CB5CDA1742572A487D9401E3400267682B202B746511891C1BAF47F8D25C07F6C39A104696DB51F17C529AD3CABE"
 decryptionKey="8A9BE8FD67AF6979E7D20198CFEA50DD3D3799C77AF2B72F"
 validation="SHA1" />
 <authorization>
 <deny users="?" />
 </authorization>  完成並編譯後即可測試,可以訪問A項目的Default.aspx頁面,就會發現頁面已經被跳轉到B項目的登錄頁面中去了,當然也可以在A項目中也設置登錄驗證頁面,登錄後又跳回A項目,顯示當前“User.Identity.Name”的值,然後再在當前窗口訪問B項目的default.aspx,也可以看到同樣的結果,當其中一個項目注銷後,訪問兩個項目的Default.ASPx都會跳轉到B項目的登錄頁面。
  關鍵部分說完了再來說說Session的問題。如果是常規的Session訪問操作辦法(非存入數據庫),AB兩個站點的Session是無法共享的,但能共享Forms 身份驗證信息,我們就可以根據這個Forms 身份驗證信息中的用戶名來新重新從數據庫中獲取需要存放到Session中的信息,然後存放到Session中供當前項目使用。
  基本流程如下:
  用戶在A網站登錄 -> A程序根據User.Identity.Name的值取得相關用戶表中的信息 -> 存放到Session["User"]中 -> 此時訪問B項目頁面 -> 程序判斷Session["User"]的值是否是Null -> 如果是Null -> B程序根據User.Identity.Name的值取得相關用戶表中的信息 -> 存放到Session["User"]中

  最後再對這個MachineKey補充下,你要覺得想省事點直接把MSDN上的加密後key復制一份就行。如果想自己生成一組Key,那麼下載我提供的這個工具(帶原代碼),運行文件在壓縮包中的Bin下面找

出處:http://blog.breakn.Net/article.ASP?id=440

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved