婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > ASP.NET 5中使用AzureAD實現單點登錄

ASP.NET 5中使用AzureAD實現單點登錄

熱門標簽:上海市三維地圖標注 安陸市地圖標注app 寧德防封版電銷卡 海東防封電銷卡 西寧電銷外呼系統公司 云南外呼系統代理 南昌自動外呼系統線路 辦公用地圖標注網點怎么操作 聊城智能電銷機器人電話

題記:在ASP.NET 5中雖然繼續可以沿用ASP.NET Identity來做驗證授權,不過也可以很容易集成支持標準協議的第三方服務,比如Azure Active Directory。

其實,在ASP.NET 5中集成AzureAD,利用其進行驗證和授權,是非常簡單的。因為:首先Azure Active Directory提供了OAuth2.0、OpenId Connect 1.0、SAML和WS-Federation 1.2標準協議接口;其次微軟在ASP.NET 5中移植了集成OpenId Connect的OWIN中間件。所以,只要在ASP.NET 5項目中引用"Microsoft.AspNet.Authentication.OpenIdConnect"這個包,并正確配置AzureAD的連接信息,就可以很容易的進行集成。

大致步驟如下:

1,在config.json文件中添加AzureAD的配置信息:

"AzureAd": {
  "ClientId": "[Enter the clientId of your application as obtained from portal, e.g. ba74781c2-53c2-442a-97c2-3d60re42f403]",
  "Tenant": "[Enter the name of your tenant, e.g. contoso.onmicrosoft.com]",
  "AadInstance": "https://login.microsoftonline.com/{0}", // This is the public instance of Azure AD
  "PostLogoutRedirectUri": https://localhost:44322/
}

2,修改project.json,引入OpenIdConnect的中間件:

"Microsoft.AspNet.Authentication.OpenIdConnect": "1.0.0-*"

3,在Startup中的ConfigureServices方法里面添加:

// OpenID Connect Authentication Requires Cookie Auth
services.ConfigureExternalAuthenticationOptions>(options =>
{
  options.SignInScheme = CookieAuthenticationDefaults.AuthenticationScheme;
});

4,在Startup中的Configure方法里面添加:

// Configure the OWIN Pipeline to use Cookie Authentication
app.UseCookieAuthentication(options => 
{
  // By default, all middleware are passive/not automatic. Making cookie middleware automatic so that it acts on all the messages.
  options.AutomaticAuthentication = true;

});

// Configure the OWIN Pipeline to use OpenId Connect Authentication
app.UseOpenIdConnectAuthentication(options =>
{
  options.ClientId = Configuration.Get("AzureAd:ClientId");
  options.Authority = String.Format(Configuration.Get("AzureAd:AadInstance"), Configuration.Get("AzureAd:Tenant"));
  options.PostLogoutRedirectUri = Configuration.Get("AzureAd:PostLogoutRedirectUri");
  options.Notifications = new OpenIdConnectAuthenticationNotifications
  {
    AuthenticationFailed = OnAuthenticationFailed,
  };
});

5,Startup的OnAuthenticationFailed方法為:

private Task OnAuthenticationFailed(AuthenticationFailedNotificationOpenIdConnectMessage, OpenIdConnectAuthenticationOptions> notification)
{
  notification.HandleResponse();
  notification.Response.Redirect("/Home/Error?message=" + notification.Exception.Message);
  return Task.FromResult(0);
}

6,添加一個名為AccountController的Controller:

public class AccountController : Controller
{
  // GET: /Account/Login
  [HttpGet]
  public IActionResult Login()
  {
    if (Context.User == null || !Context.User.Identity.IsAuthenticated)
      return new ChallengeResult(OpenIdConnectAuthenticationDefaults.AuthenticationScheme, new AuthenticationProperties { RedirectUri = "/" });
    return RedirectToAction("Index", "Home");
  }

  // GET: /Account/LogOff
  [HttpGet]
  public IActionResult LogOff()
  {
    if (Context.User.Identity.IsAuthenticated)
    {
      Context.Authentication.SignOut(CookieAuthenticationDefaults.AuthenticationScheme);
      Context.Authentication.SignOut(OpenIdConnectAuthenticationDefaults.AuthenticationScheme);
    }
    return RedirectToAction("Index", "Home");
  }
}

以上代碼也可以到我Fork的完整示例項目中找到:https://github.com/heavenwing/WebApp-OpenIdConnect-AspNet5

【更新:2015-07-16】
如果你遇到添加了 [Authorize] ,但是不能自動轉到登錄頁面的情況,那么需要:

app.UseOpenIdConnectAuthentication(options => {
  options.AutomaticAuthentication = true;
});

具體見:https://github.com/aspnet/Security/issues/357#issuecomment-120834369

以上所述就是本文的全部內容了,希望大家能夠喜歡。

您可能感興趣的文章:
  • Azure給ubuntu虛擬機掛載數據盤的詳細步驟
  • 詳解在Azure上部署Asp.NET Core Web App
  • Windows Azure 平臺重置Linux密碼的方法
  • 如何解決在Azure上部署Sqlserver網絡訪問不了
  • 在 Ubuntu Linux 上安裝 Oracle Java 14的方法
  • Java遠程連接Linux服務器并執行命令及上傳文件功能
  • 詳解在LINUX上部署帶有JAR包的JAVA項目
  • Java啟用Azure Linux虛擬機診斷設置

標簽:青海 洛陽 南寧 崇左 汕尾 衢州 贛州 平涼

巨人網絡通訊聲明:本文標題《ASP.NET 5中使用AzureAD實現單點登錄》,本文關鍵詞  ASP.NET,中,使用,AzureAD,實現,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《ASP.NET 5中使用AzureAD實現單點登錄》相關的同類信息!
  • 本頁收集關于ASP.NET 5中使用AzureAD實現單點登錄的相關信息資訊供網民參考!
  • 推薦文章
    主站蜘蛛池模板: 龙川县| 双牌县| 喀喇沁旗| 定西市| 岳普湖县| 上杭县| 白河县| 长汀县| 江都市| 惠州市| 凤山县| 门源| 库尔勒市| 鄂托克旗| 历史| 株洲县| 冕宁县| 抚顺县| 遵化市| 韩城市| 大庆市| 洛宁县| 亚东县| 乌恰县| 钟祥市| 通江县| 雷波县| 胶州市| 济阳县| 柘荣县| 贵州省| 东明县| 许昌市| 边坝县| 常山县| 增城市| 巴林右旗| 宣城市| 鹰潭市| 文化| 乐都县|