我有一个使用身份服务器4的身份服务器。当新用户注册时,我们向他们发送确认电子邮件
var callbackUrl = Url.EmailConfirmationLink(user.Id.ToString(), code, Request.Scheme);
if (_emailSender.SendEmailConfirmation(model.Email, callbackUrl, out var errors))
return RedirectToAction("CreateUserConfirmation");
发送给用户的网址如下
重定向回应用程序
当应用程序定向到Identity Server进行用户登录时,它将发送一个returnurl。该网址用于在用户登录后
使用户返回到应用程序returnurl = / connect / authorize / callback?client_id = XenaClient&redirect_uri = http%3A%2F%2Flocalhost%3A49000%2Fsignin-oidc&response_mode = form_post&response_type = id_token%20token%20code&scope = openid%20profile%Environment = 4% 5TgYhVg5nQnRpvZYC1C8y12c5VTheRQlVI5y6GzTzgJCsuPTx_NoPVIFXY2ZSZKbhs4VxQ0HjJik4LGF0E2ToFAFDuonTJC3WwNSlFPN5eTrsbqebms-fqZq7dcpUOjhYU-kLpGcKSyaSXe5qr0EOanqIdEyV9H0EZolq38pjvBJWFf0bWC6KPNCZ4Nw&随机数= 636705214204045725.YWI1YmVhNDQtYTE4MC00ZDIwLWJmMDQtYjA3YzNmMGYyODg3ZTNhNTNlMmEtNzQ1YS00M2Y4LWI2N2YtODY4MDg5OGNmYzNj
这对现有用户很好。
重定向新用户
新用户注册帐户时,发送给他们的电子邮件不会将他们重定向回应用程序。它们留在身份服务器本身上。
添加returnurl以确认电子邮件(我尝试过的操作)
我想做的是将returnurl粘贴到确认URL电子邮件上。这样,当用户确认他们的电子邮件时,他们就会被路由回
public async Task<IActionResult> ConfirmEmail([FromQuery] string userId, [FromQuery] string code,[FromQuery] string returnUrl = null)
{
............
return (returnUrl == null)
? RedirectToAction("Login")
: RedirectToLocal(returnUrl);
}
电子邮件中发送的巨大网址看起来像这样
URL长
问题是当返回URL上面的方法是/connect/authorize/callback?client_id=XenaClient
时,这不是我要发送的完整URL的长度1457,我怀疑服务器解析的时间太长了吗?
问题
因此,如果请求时间过长,如何将用户返回到应用程序。请注意,将其默认设置为单个url不会起作用,因为我们有多个使用此身份服务器的应用程序,并且无法知道用户最初来自哪个应用程序。
答案 0 :(得分:0)
我终于做到了。当用户注册时,我有returnUrl,其中包含redirect_uri。现在,我们将假定该应用程序位于相同的域和端口上。因此,我删除了重定向uri。
var pat = "redirect_uri=([^&]+)";
var r = new Regex(pat, RegexOptions.IgnoreCase);
var m = r.Match(returnurl);
然后我可以将此较小的uri添加到电子邮件配置链接
public static string EmailConfirmationLink(this IUrlHelper urlHelper, string userId, string code, string scheme, string returnUrl = "")
{
return urlHelper.Action(
action: nameof(AccountController.ConfirmEmail),
controller: "Account",
values: new { userId, code, returnUrl },
protocol: scheme);
}
当用户单击链接时,我确认其电子邮件,然后将其重新路由到从重定向uri翻录的域中。
return Redirect(returnUrl);
问题
现在,假设重定向uri和原始应用程序的主机位于同一域上,这应该可以工作。据我所知,目前是。额外的结果是,如果他们尝试在生产中使用本地主机重定向uri,它将导致重大问题,并且无法正确重定向。这可能是一件好事,因为我希望第三方开发人员在生产中不要将localhost作为重定向uri。
如果有人有更好的解决方案,我还是很想听听它,因为这感觉像是一个小小的黑客。但是我们需要尽快解决此问题,因此我决定忍受黑客攻击,直到找到更好的解决方案