我偶然发现应用程序将用户重定向到Account/AccessDenied/
时出现的问题不一致,因为向当前登录的用户添加社交媒体验证。它似乎在用户第一次登录时工作,然后尝试添加另一种验证方法,它将用户返回到Account/AccessDenied?ReturnUrl=%2Fmanage%2Flinklogincallback
。应用程序重定向到帐户/ AccessDenied添加Oauth
我的猜测是[Authorize]属性有问题,但只是第二次尝试添加外部验证方法。
ManageController
[Authorize]
public class ManageController : Controller
{
//
// POST: /Manage/LinkLogin
[HttpPost]
[ValidateAntiForgeryToken]
public IActionResult LinkLogin(string provider)
{
// Request a redirect to the external login provider to link a login for the current user
var redirectUrl = Url.Action("LinkLoginCallback", "Manage");
var properties = _signInManager.ConfigureExternalAuthenticationProperties(provider, redirectUrl, _userManager.GetUserId(User));
return Challenge(properties, provider);
}
//
// GET: /Manage/LinkLoginCallback
[HttpGet]
public async Task<ActionResult> LinkLoginCallback()
{
var user = await GetCurrentUserAsync();
if (user == null)
{
return View("Error");
}
var info = await _signInManager.GetExternalLoginInfoAsync(await _userManager.GetUserIdAsync(user));
if (info == null)
{
return RedirectToAction(nameof(ManageLogins), new { Message = ManageMessageId.Error });
}
var result = await _userManager.AddLoginAsync(user, info);
var message = result.Succeeded ? ManageMessageId.AddLoginSuccess : ManageMessageId.Error;
return RedirectToAction(nameof(ManageLogins), new { Message = message });
}
}
它可能是如何startup.cs被安排的顺序?
这是请求/响应
此错误是否一致? 因为当我的代码仍然抛出错误异常时,我得到了很多错误。清除cookie可以暂时解决问题。后来当我修复我的小错误时,这个redirectd不再发生。 –
它一贯发生,但我不知道它是什么,因为一切都按预期工作。你为了使它工作而修复了哪些微不足道的错误? – Rovdjuret
您是否在'Startup'类的'Configure()'方法中添加了'app.UseGoogleAuthentication(...)'? –