OAuthSetup.cs 2.2 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253
  1. // 麻省理工学院许可证
  2. //
  3. // 版权所有 (c) 2021-2023 zuohuaijun,大名科技(天津)有限公司 联系电话/微信:18020030720 QQ:515096995
  4. //
  5. // 特此免费授予获得本软件的任何人以处理本软件的权利,但须遵守以下条件:在所有副本或重要部分的软件中必须包括上述版权声明和本许可声明。
  6. //
  7. // 软件按“原样”提供,不提供任何形式的明示或暗示的保证,包括但不限于对适销性、适用性和非侵权的保证。
  8. // 在任何情况下,作者或版权持有人均不对任何索赔、损害或其他责任负责,无论是因合同、侵权或其他方式引起的,与软件或其使用或其他交易有关。
  9. using Microsoft.AspNetCore.Authentication;
  10. using Microsoft.AspNetCore.Authentication.Cookies;
  11. using Microsoft.AspNetCore.Authentication.JwtBearer;
  12. using Microsoft.AspNetCore.Builder;
  13. namespace Admin.NET.Core;
  14. public static class OAuthSetup
  15. {
  16. /// <summary>
  17. /// 三方授权登录OAuth注册
  18. /// </summary>
  19. /// <param name="services"></param>
  20. public static void AddOAuth(this IServiceCollection services)
  21. {
  22. var authOpt = App.GetConfig<OAuthOptions>("OAuth", true);
  23. services.AddAuthentication(options =>
  24. {
  25. options.DefaultScheme = CookieAuthenticationDefaults.AuthenticationScheme;
  26. options.DefaultAuthenticateScheme = JwtBearerDefaults.AuthenticationScheme;
  27. })
  28. .AddCookie(options =>
  29. {
  30. options.Cookie.SameSite = SameSiteMode.Lax;
  31. })
  32. .AddWeixin(options =>
  33. {
  34. options.ClientId = authOpt.Weixin?.ClientId;
  35. options.ClientSecret = authOpt.Weixin?.ClientSecret;
  36. })
  37. .AddGitee(options =>
  38. {
  39. options.ClientId = authOpt.Gitee?.ClientId;
  40. options.ClientSecret = authOpt.Gitee?.ClientSecret;
  41. options.ClaimActions.MapJsonKey(OAuthClaim.GiteeAvatarUrl, "avatar_url");
  42. });
  43. }
  44. public static void UseOAuth(this IApplicationBuilder app)
  45. {
  46. app.UseCookiePolicy(new CookiePolicyOptions { MinimumSameSitePolicy = SameSiteMode.Lax });
  47. }
  48. }