为了账号安全,请及时绑定邮箱和手机立即绑定

状态 cookie 无效。处理远程登录时遇到错误。ASP.NET Core MVC 外部社交登录

状态 cookie 无效。处理远程登录时遇到错误。ASP.NET Core MVC 外部社交登录

C#
炎炎设计 2023-07-22 18:19:38
在没有 ASP.NET Core Identity 的情况下在 ASP.NET Core2.2 MVC Web 应用程序中实现外部社交登录。成功登录 Google、Facebook、Twitter、LinkedIn 和 Microsoft 后,我在重定向回应用程序时收到以下错误。处理请求时发生未处理的异常。异常:无效的状态 cookie。地点未知异常:处理远程登录时遇到错误。Microsoft.AspNetCore.Authentication.RemoteAuthenticationHandler.HandleRequestAsync()以下是Startup.cs文件中的设置public void ConfigureServices(IServiceCollection services)   {       services.Configure<CookiePolicyOptions>(options =>       {           // This lambda determines whether user consent for non-essential cookies is needed for a given request.           options.CheckConsentNeeded = context => true;           options.MinimumSameSitePolicy = SameSiteMode.None;       });       services           .AddAuthentication(options =>           {               options.DefaultScheme = CookieAuthenticationDefaults.AuthenticationScheme;               options.DefaultChallengeScheme = GoogleDefaults.AuthenticationScheme;           })           .AddCookie(options =>           {               options.Cookie.IsEssential = true;           })           .AddGoogle(options =>           {               options.SignInScheme = CookieAuthenticationDefaults.AuthenticationScheme;               options.ClientId = Configuration["Authentication:Google:ClientId"];               options.ClientSecret = Configuration["Authentication:Google:ClientSecret"];               options.CallbackPath = "/externallogincallback";                        })           .AddFacebook(facebookOptions =>           {               facebookOptions.AppId = Configuration["Authentication:Facebook:AppId"];               facebookOptions.AppSecret = Configuration["Authentication:Facebook:AppSecret"];               facebookOptions.CallbackPath = "/externallogincallback";                                                   })
查看完整描述

1 回答

?
慕的地6264312

TA贡献1817条经验 获得超6个赞

externallogincallback您似乎想在登录 Microsoft 帐户后将请求重定向到。如果是这样,则不应microsoftOptions.CallbackPath设置externallogincallback. 通过此设置,来自 Microsoft 的所有请求都将由 OAuth 中间件而不是您自己的端点处理externallogincallback

对于登录后重定向页面,您需要return Challenge(authenticationProperties, provider);通过设置authenticationProperties.authenticationProperties

请按照以下步骤操作:

  1. REDIRECT URI在 Azure 门户中更改https://localhost:xxx/signin-microsoft

  2. 更改Startup.cs

public class Startup

{

    public Startup(IConfiguration configuration)

    {

        Configuration = configuration;

    }


    public IConfiguration Configuration { get; }


    // This method gets called by the runtime. Use this method to add services to the container.

    public void ConfigureServices(IServiceCollection services)

    {

        services.Configure<CookiePolicyOptions>(options =>

        {

            // This lambda determines whether user consent for non-essential cookies is needed for a given request.

            options.CheckConsentNeeded = context => true;

            options.MinimumSameSitePolicy = SameSiteMode.None;

        });



        services.AddMvc().SetCompatibilityVersion(CompatibilityVersion.Version_2_2);


        services.AddAuthentication(options =>

            {

                options.DefaultScheme = CookieAuthenticationDefaults.AuthenticationScheme;

                //options.DefaultChallengeScheme = GoogleDefaults.AuthenticationScheme;

            })

            .AddCookie(options =>

            {

                options.Cookie.IsEssential = true;

                //options.Cookie.SameSite = SameSiteMode.None;

            })

            .AddMicrosoftAccount(microsoftOptions =>

            {

                microsoftOptions.SignInScheme = CookieAuthenticationDefaults.AuthenticationScheme;

                microsoftOptions.ClientId = Configuration["Authentication:Microsoft:ClientId"];

                microsoftOptions.ClientSecret = Configuration["Authentication:Microsoft:ClientSecret"];                    

            });

    }


    // This method gets called by the runtime. Use this method to configure the HTTP request pipeline.

    public void Configure(IApplicationBuilder app, IHostingEnvironment env)

    {

        if (env.IsDevelopment())

        {

            app.UseDeveloperExceptionPage();

        }

        else

        {

            app.UseExceptionHandler("/Home/Error");

            // The default HSTS value is 30 days. You may want to change this for production scenarios, see https://aka.ms/aspnetcore-hsts.

            app.UseHsts();

        }


        app.UseHttpsRedirection();

        app.UseStaticFiles();

        app.UseCookiePolicy();

        app.UseAuthentication();

        app.UseMvc(routes =>

        {

            routes.MapRoute(

                name: "default",

                template: "{controller=Home}/{action=Index}/{id?}");

        });

    }

}

家庭控制器


public class HomeController : Controller

{

    //Action to issue a challange to google login

    public IActionResult LogInMicrosoft(string provider)

    {

        //provider = Microsot or Google or LinkedIn or Twitter or Facebook

        provider = "Microsoft";

        var authenticationProperties = new AuthenticationProperties

        {

            RedirectUri = Url.Action("externallogincallback")

        };

        return Challenge(authenticationProperties, provider);

    }


    [Route("/[action]")]

    public async Task<IActionResult> externallogincallback()

    {

        var request = HttpContext.Request;

        //Here we can retrieve the claims

        // read external identity from the temporary cookie

        //var authenticateResult = HttpContext.GetOwinContext().Authentication.AuthenticateAsync("ExternalCookie");

        var result = await HttpContext.AuthenticateAsync(CookieAuthenticationDefaults.AuthenticationScheme);


        if (result.Succeeded != true)

        {

            throw new Exception("External authentication error");

        }


        // retrieve claims of the external user

        var externalUser = result.Principal;

        if (externalUser == null)

        {

            throw new Exception("External authentication error");

        }


        // retrieve claims of the external user

        var claims = externalUser.Claims.ToList();


        // try to determine the unique id of the external user - the most common claim type for that are the sub claim and the NameIdentifier

        // depending on the external provider, some other claim type might be used

        //var userIdClaim = claims.FirstOrDefault(x => x.Type == JwtClaimTypes.Subject);

        var userIdClaim = claims.FirstOrDefault(x => x.Type == ClaimTypes.NameIdentifier);

        if (userIdClaim == null)

        {

            throw new Exception("Unknown userid");

        }


        var externalUserId = userIdClaim.Value;

        var externalProvider = userIdClaim.Issuer;


        // use externalProvider and externalUserId to find your user, or provision a new user


        return RedirectToAction("Privacy", "Home");

    }

    public IActionResult Index()

    {

        return View();

    }


    public IActionResult Privacy()

    {

        return View();

    }


    [ResponseCache(Duration = 0, Location = ResponseCacheLocation.None, NoStore = true)]

    public IActionResult Error()

    {

        return View(new ErrorViewModel { RequestId = Activity.Current?.Id ?? HttpContext.TraceIdentifier });

    }

}



查看完整回答
反对 回复 2023-07-22
  • 1 回答
  • 0 关注
  • 100 浏览

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信