2017-07-17 70 views
0

我有以下线返回null为Twitter和微软的问题:Owin OAuth的提供商Twitter和微软

var loginInfo = await AuthenticationManager.GetExternalLoginInfoAsync(); 

这是在账户控制器象下面这样:

[AllowAnonymous] 
public async Task<ActionResult> ExternalLoginCallback(string returnUrl) 
{ 
    var loginInfo = await 
    AuthenticationManager.GetExternalLoginInfoAsync(); 

    if (loginInfo == null) 
    { 
     return RedirectToAction("Login"); 
    } 

    var result = await SignInManager.ExternalSignInAsync(loginInfo, false); 
    switch (result) 
    { 
     case SignInStatus.Success: 
      return RedirectToLocal(returnUrl); 
     case SignInStatus.LockedOut: 
      return View("Lockout"); 
     //case SignInStatus.RequiresVerification: 
     // return RedirectToAction("SendCode", new { ReturnUrl = returnUrl, RememberMe = false }); 
     case SignInStatus.Failure: 
     default: 
      // If the user does not have an account, then prompt the user to create an account 
      ViewBag.ReturnUrl = returnUrl; 
      ViewBag.LoginProvider = loginInfo.Login.LoginProvider; 
      return View("ExternalLoginConfirmation", new AccountExternalLoginConfirmationViewModel { Email = loginInfo.Email }); 
    } 
} 

在启动.auth.cs当前的配置是:

app.UseTwitterAuthentication(
    new TwitterAuthenticationOptions() 
    { 
     ConsumerKey = ConfigurationManager.AppSettings["TwitterAPIKey"], 
     ConsumerSecret = ConfigurationManager.AppSettings["TwitterAPISecret"], 

     Provider = new TwitterAuthenticationProvider() 
     { 
      OnAuthenticated = context => 
      { 
       context.Identity.AddClaim(new Claim("urn:tokens:twitter:accesstoken", context.AccessToken)); 
       context.Identity.AddClaim(new Claim("urn:tokens:twitter:accesstokensecret", 
        context.AccessTokenSecret)); 
       return Task.FromResult(true); 
      } 
     } 
    }); 

     app.UseMicrosoftAccountAuthentication(new MicrosoftAccountAuthenticationOptions() 
     { 
      ClientId = ConfigurationManager.AppSettings["MicrosoftAPIKey"], 
      ClientSecret = ConfigurationManager.AppSettings["MicrosoftAPISecret"], 
      // Scope = { "wl.basic", "wl.emails" }, 
      Provider = new MicrosoftAccountAuthenticationProvider() 
      { 
       OnAuthenticated = context => 
       { 
        context.Identity.AddClaim(new Claim("urn:microsoftaccount:access_token", context.AccessToken, "Microsoft")); 
        context.Identity.AddClaim(new Claim("urn:microsoft:email", context.Email)); 
        return Task.FromResult(true); 
       } 
      } 
     }); 

已经建议包括Scope = { “Microsoft.AccountAuthenticationOptions”中的“wl.basic”,“wl.emails”}。然而,这返回一个不好的请求。任何关于如何通过twitter和microsoft登录解决此问题的想法。

我的网址我使用微软的 重定向URL:https://localhost/signin-microsoft 注销URL:https://localhost/account/logout 主页:https://localhost

Twitter的 网站:https://127.0.0.1 回拨网址:https://127.0.0.1/signin-twitter

我已经活尝试在live上的url也是,而且在 上仍然是null var loginInfo = await AuthenticationManager.GetExternalLoginInfoAsync();

+0

嗨,你有没有找到这个问题的解决方案?我有同样的问题,但没有找到我找到的解决方案。 –

回答

0

试试这个:

var options = new TwitterAuthenticationOptions { SignInAsAuthenticationType = signInAsType, ConsumerKey = "...", ConsumerSecret = "...", Provider = new TwitterAuthenticationProvider() { OnAuthenticated = async ctx => { var manager = new OAuth.Manager( "-your-twitter-access-token-", "-your-twitter-access-token-secret-", ctx.AccessToken, ctx.AccessTokenSecret); var url = "https://api.twitter.com/1.1/account/verify_credentials.json"; var authzHeader = manager.GenerateAuthzHeader(url, "GET"); var request = (HttpWebRequest)WebRequest.Create(url); request.Method = "GET"; request.PreAuthenticate = true; request.AllowWriteStreamBuffering = true; request.Headers.Add("Authorization", authzHeader); using (var response = (HttpWebResponse)request.GetResponse()) { if (response.StatusCode != HttpStatusCode.OK) throw new Exception("NOK"); var responseStream = response.GetResponseStream(); var reader = new System.IO.StreamReader(responseStream); var res = reader.ReadToEnd(); Newtonsoft.Json.Linq.JObject data = (Newtonsoft.Json.Linq.JObject)JsonConvert.DeserializeObject(res); var claims = new List<Claim>(); claims.Add(new Claim(Core.Constants.ClaimTypes.RawData, ctx.Identity.Claims.ToJsonString())); claims.Add(new Claim(Core.Constants.ClaimTypes.AccessToken, ctx.AccessToken)); claims.Add(new Claim(Core.Constants.ClaimTypes.AccessTokenSecret, ctx.AccessTokenSecret)); claims.Add(new Claim(Core.Constants.ClaimTypes.Subject, ctx.UserId)); claims.Add(new Claim(Core.Constants.ClaimTypes.Name, data["name"].TokenString())); claims.Add(new Claim(Core.Constants.ClaimTypes.Locale, GenerateLocale(data["lang"].TokenString()))); claims.Add(new Claim(Core.Constants.ClaimTypes.ZoneInfo, GenerateZone(data["location"].TokenString(), data["time_zone"].TokenString()))); claims.Add(new Claim(Core.Constants.ClaimTypes.WebSite, data["url"].TokenString())); claims.Add(new Claim(Core.Constants.ClaimTypes.ProfileUrl, "https://twitter.com/" + ctx.ScreenName)); claims.Add(new Claim(Core.Constants.ClaimTypes.Picture, data["profile_image_url"].TokenString())); await PrepClaims(ctx.Identity, claims); } } }