【问题标题】:ClaimTypes for getting the user's profile image in mvc 6在 mvc 6 中获取用户个人资料图像的 ClaimTypes
【发布时间】:2025-11-23 05:55:02
【问题描述】:

这是我的ExternalLoginConfirmation 任务,这是创建项目时添加的默认代码。我添加了这些行来获取用户声明:

user.Firstname = info.Principal.Claims.FirstOrDefault(c => c.Type == ClaimTypes.GivenName)?.ToString();
user.Lastname = info.Principal.Claims.FirstOrDefault(c => c.Type == ClaimTypes.Surname)?.ToString();
user.Gender = info.Principal.Claims.FirstOrDefault(c => c.Type == ClaimTypes.Gender)?.ToString();

但是我无法获取用户个人资料图片,因为它在 ClaimTypes 中不存在。

    public async Task<IActionResult> ExternalLoginConfirmation(ExternalLoginConfirmationViewModel model, string returnUrl = null)
    {
        if (ModelState.IsValid)
        {
            // Get the information about the user from the external login provider
            var info = await _signInManager.GetExternalLoginInfoAsync();
            if (info == null)
            {
                return View("ExternalLoginFailure");
            }
            var user = new ApplicationUser { UserName = model.Email, Email = model.Email };
            var result = await _userManager.CreateAsync(user);
            if (result.Succeeded)
            {
                result = await _userManager.AddLoginAsync(user, info);
                if (result.Succeeded)
                {
                    user.Firstname = info.Principal.Claims.FirstOrDefault(c => c.Type == ClaimTypes.GivenName)?.ToString();
                    user.Lastname = info.Principal.Claims.FirstOrDefault(c => c.Type == ClaimTypes.Surname)?.ToString();
                    user.Gender = info.Principal.Claims.FirstOrDefault(c => c.Type == ClaimTypes.Gender)?.ToString();

                    await _signInManager.SignInAsync(user, isPersistent: false);
                    _logger.LogInformation(6, "User created an account using {Name} provider.", info.LoginProvider);
                    return RedirectToLocal(returnUrl);
                }
            }
            AddErrors(result);
        }

        ViewData["ReturnUrl"] = returnUrl;
        return View(model);
    }

请注意,info 缺少 ExternalPrincipal 并且以下功能也不可用:

info.ExternalPrincipal.FindFirstValue("pictureUrl"); 

【问题讨论】:

  • 找到答案了吗?
  • @Diomedes google 已停止提供这样的个人资料图片,您应该启用 google plus api,并使用提供的 api 密钥请求个人资料图片。我将在一分钟内添加我正在使用的解决方案。只需检查答案
  • @Diomedes 我添加了答案(从我自己的项目中复制)。我只是获取图像链接并将其添加到我的数据库中,您可能需要对其进行修改。

标签: c# asp.net-mvc oauth


【解决方案1】:

这是我现在使用的灵魂:

 var result = await _userManager.CreateAsync(user);
       if (result.Succeeded)
       {
            result = await _userManager.AddLoginAsync(user, info);
            if (result.Succeeded)
            {
                 if (info.LoginProvider.ToLower().IndexOf("google") != -1)
                    { await _userManager.AddClaimAsync(user, new Claim("GooglePlusId", info.ProviderKey));
                        try {
                                HttpClient client = new HttpClient();
                                HttpResponseMessage x = await client.GetAsync($"https://www.googleapis.com/plus/v1/people/{info.ProviderKey}?fields=image&key=YOUR_GOOGLE_PLUS_API_KEY");
                               dynamic img = Newtonsoft.Json.JsonConvert.DeserializeObject(await x.Content.ReadAsStringAsync());
                                user.PhotoLink = img.image.url;
                                db.SaveChanges();
                            }
                            catch { }

                    }

                        if (info.LoginProvider.ToLower().IndexOf("facebook") != -1)
                        {
                            user.PhotoLink = $"http://graph.facebook.com/{info.ProviderKey}/picture?type=square&width=50";
                        }   
                        await _signInManager.SignInAsync(user, isPersistent: false);
                        _logger.LogInformation(6, "User created an account using {Name} provider.", info.LoginProvider);
                        return RedirectToLocal(returnUrl);
                    }
                }

P.S.:此代码应添加到 AccountControllers 控制器中的 ExternalLoginConfirmation 操作中

【讨论】:

    最近更新 更多