佳木斯湛栽影视文化发展公司

主頁 > 知識庫 > 如何在不同.net版本實現(xiàn)單點登錄

如何在不同.net版本實現(xiàn)單點登錄

熱門標簽:電商新玩法 客戶服務(wù) 人工智能 電銷業(yè)務(wù) 科大訊飛語音識別系統(tǒng) 國美全國運營中心 網(wǎng)站排名優(yōu)化 百度AI接口

所謂單點登錄(Single Sign On就是在多個應(yīng)用系統(tǒng)中,用戶只需要登錄一次就可以訪問所有相互信任的應(yīng)用系統(tǒng)。其實對于程序員在技術(shù)上要實現(xiàn)就得就是多個不同域名間共享cookie的問題。

最近在為ERP添加一個部署在另一臺機器上,鏈接到原有老系統(tǒng)中的子項目,調(diào)用原有老項目中的Login實現(xiàn)單點登錄,嘗試了N次屢試不成,最后確定問題,是,.net2.0與4.0中對cookie的加密/解密方法由此差異,于是經(jīng)過研究,重寫實現(xiàn)了一個可以在不同.net版本中實現(xiàn)單點登錄的簡單方法。

1,共用登陸頁代碼實現(xiàn):

復(fù)制代碼 代碼如下:

protected void btnLogin_Click(object sender, EventArgs e)
{
  //認證開票,跳轉(zhuǎn)到原始請求頁面
   System.Web.Security.FormsAuthentication.RedirectFromLoginPage("ejiyuan", false);
}

2,配置文件:
復(fù)制代碼 代碼如下:

!--訪問權(quán)限控制-->
authorization>
    deny users="?"/>
/authorization>   
!--身份認證方式-->
authentication mode="Forms">
    forms name=".ASPNET" protection="All" enableCrossAppRedirects="true" loginUrl="Login.aspx" timeout="2880" path="/" domain=".local.com"/>
/authentication>  
!--驗證算法-->
machineKey validationKey="F9D1A2D3E1D3E2F7B3D9F90FF3965ABDAC304902" decryptionKey="F9D1A2D3E1D3E2F7B3D9F90FF3965ABDAC304902F8D923AC" validation="SHA1" decryption="3DES" /> compilation debug="true"/>

這里:authentication/forms節(jié)點最重要的兩個屬性是name和protection. 所有實現(xiàn)單點登錄的項目都要是相同的配置就這樣,才可以在不同程序中同樣的保護級別下讀寫Cookie
當(dāng) protection屬性設(shè)置為 "All",通過Hash值進行加密和驗證數(shù)據(jù)都存放在Cookie中.默認的驗證和加密使用的Key都存儲在machine.config文件,我們可以在應(yīng)用程序的Web.Config文件覆蓋這些值.默認值如下:

machineKeyvalidationKey="AutoGenerate,IsolateApps"decryptionKey=" AutoGenerate,IsolateApps"validation="SHA1" />

IsolateApps表示為每個應(yīng)用程序生成不同的Key.我們不能使用這個.為了能在多個應(yīng)用程序中使用相同的Key來加密解密cookie,我們可以移除IsolateApps 選項或者更好的方法是在所有需要實現(xiàn)SSO的應(yīng)用程序的Web.Config中設(shè)置一個具體的Key值:

machineKey validationKey="F9D1A2D3E1D3E2F7B3D9F90FF3965ABDAC304902" decryptionKey="F9D1A2D3E1D3E2F7B3D9F90FF3965ABDAC304902F8D923AC" validation="SHA1" decryption="3DES" /> compilation debug="true"/>

如果你使用同樣的存儲方式,實現(xiàn)SSO只是改動一下Web.config而已,必須保證單點中的每個應(yīng)用程序都有相同的配置,如果單點登錄的應(yīng)用程序是跨不同.net版本的,這里的加密/解密不要使用md5

machineKey decryptionKey="8B6697227CBCA902B1A0925D00FAA00B353F2DF4359D2099" validation="MD5" validationKey="282487E295028E59B8F411ACB689CCD6F39DDD2146055A3EE480424315994760ADF21B580D8587DB675FA02F7916813044E25309CCCDB647174D5B3D0DD9141"/>

3,沒有登錄頁的單點登錄不需要代碼 直接配置就可以了,配置如下

復(fù)制代碼 代碼如下:

authorization>
  deny users="?"/>
/authorization>
authentication mode="Forms">
    forms name=".ASPNET" protection="All" enableCrossAppRedirects="true" loginUrl="http://Sso2.local.com/Login.aspx" timeout="2880" path="/" domain=".local.com"/>
/authentication>

4,登錄模塊從定向代碼封裝在httpModules中供其他系統(tǒng)直接調(diào)用,這里附上封裝代碼與引用方法:
復(fù)制代碼 代碼如下:

public class SsoLoginRedirectModule : IHttpModule
{
    public void Init(HttpApplication i_application)
    {
        // TODO:  Add UploadModule.Init implementation   
        i_application.EndRequest += new EventHandler(i_application_EndRequest);
    }

    void i_application_EndRequest(object sender, EventArgs e)
    {
        if ((HttpContext.Current.Response.StatusCode == 302) HttpContext.Current.Response.RedirectLocation.Contains(FormsAuthentication.LoginUrl))
        {
            HttpContext.Current.Response.RedirectLocation = FormsAuthentication.LoginUrl + "?ReturnUrl=" + HttpUtility.UrlEncode(HttpContext.Current.Request.Url.OriginalString);
        }
    }

    public void Dispose()
    {
        //throw new NotImplementedException();
    }
}


引用: 
復(fù)制代碼 代碼如下:

httpModules>
    add name="SsoModule" type="SsoModule.SsoLoginRedirectModule, SsoModule"/>
/httpModules>

您可能感興趣的文章:
  • asp.net簡單實現(xiàn)單點登錄(SSO)的方法
  • .NET 單點登錄解決方案
  • 基于.Net的單點登錄(SSO)實現(xiàn)解決方案
  • 一個簡單的asp.net 單點登錄實現(xiàn)
  • 在ASP.NET 中實現(xiàn)單點登錄
  • .net core 1.0 實現(xiàn)單點登錄負載多服務(wù)器

標簽:咸寧 益陽 拉薩 POS機 攀枝花 廈門 南平 棗莊

巨人網(wǎng)絡(luò)通訊聲明:本文標題《如何在不同.net版本實現(xiàn)單點登錄》,本文關(guān)鍵詞  ;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 收縮
    • 微信客服
    • 微信二維碼
    • 電話咨詢

    • 400-1100-266
    临西县| 涡阳县| 论坛| 石棉县| 定远县| 溆浦县| 白城市| 双柏县| 咸阳市| 东乡族自治县| 临西县| 黑山县| 六枝特区| 清涧县| 鄂州市| 嘉义县| 井陉县| 博野县| 茶陵县| 德安县| 邯郸县| 禹州市| 财经| 双鸭山市| 大安市| 嘉善县| 习水县| 达州市| 大新县| 视频| 称多县| 泸溪县| 桓仁| 德州市| 淮阳县| 阆中市| 丹巴县| 东丰县| 出国| 泽库县| 西峡县|