WeChatService.cs 4.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113
  1. namespace Admin.NET.Core.Service;
  2. /// <summary>
  3. /// 微信公众号服务
  4. /// </summary>
  5. [ApiDescriptionSettings(Order = 101)]
  6. public class WeChatService : IDynamicApiController, ITransient
  7. {
  8. private readonly SqlSugarRepository<WeChatUser> _weChatUserRep;
  9. private readonly WechatApiClient _weChatApiClient;
  10. public WeChatService(SqlSugarRepository<WeChatUser> weChatUserRep,
  11. WeChatApiHttpClient weChatApiHttpClient)
  12. {
  13. _weChatUserRep = weChatUserRep;
  14. _weChatApiClient = weChatApiHttpClient.CreateWeChatClient();
  15. }
  16. /// <summary>
  17. /// 生成网页授权Url
  18. /// </summary>
  19. /// <param name="input"></param>
  20. /// <returns></returns>
  21. [HttpPost("/weChat/genAuthUrl")]
  22. [AllowAnonymous]
  23. public string GenAuthUrl(GenAuthUrlInput input)
  24. {
  25. return _weChatApiClient.GenerateParameterizedUrlForConnectOAuth2Authorize(input.RedirectUrl, input.Scope);
  26. }
  27. /// <summary>
  28. /// 授权登录(Code换取OpenId)
  29. /// </summary>
  30. /// <param name="input"></param>
  31. [HttpPost("/weChat/snsOAuth2")]
  32. [AllowAnonymous]
  33. public async Task<string> LoginOAuth2([Required] WeChatOAuth2Input input)
  34. {
  35. var reqOAuth2 = new SnsOAuth2AccessTokenRequest()
  36. {
  37. Code = input.Code,
  38. };
  39. var resOAuth2 = await _weChatApiClient.ExecuteSnsOAuth2AccessTokenAsync(reqOAuth2);
  40. if (resOAuth2.ErrorCode != (int)WeChatReturnCodeEnum.请求成功)
  41. throw Oops.Oh(resOAuth2.ErrorMessage + resOAuth2.ErrorCode);
  42. var wxUser = await _weChatUserRep.GetFirstAsync(p => p.OpenId == resOAuth2.OpenId);
  43. if (wxUser == null)
  44. {
  45. var reqUserInfo = new SnsUserInfoRequest()
  46. {
  47. OpenId = resOAuth2.OpenId,
  48. AccessToken = resOAuth2.AccessToken,
  49. };
  50. var resUserInfo = await _weChatApiClient.ExecuteSnsUserInfoAsync(reqUserInfo);
  51. wxUser = resUserInfo.Adapt<WeChatUser>();
  52. wxUser.Avatar = resUserInfo.HeadImageUrl;
  53. wxUser.NickName = resUserInfo.Nickname;
  54. wxUser = await _weChatUserRep.AsInsertable(wxUser).ExecuteReturnEntityAsync();
  55. }
  56. else
  57. {
  58. wxUser.AccessToken = resOAuth2.AccessToken;
  59. wxUser.RefreshToken = resOAuth2.RefreshToken;
  60. await _weChatUserRep.AsUpdateable(wxUser).IgnoreColumns(true).ExecuteCommandAsync();
  61. }
  62. return resOAuth2.OpenId;
  63. }
  64. /// <summary>
  65. /// 微信用户登录
  66. /// </summary>
  67. /// <param name="input"></param>
  68. /// <returns></returns>
  69. [HttpPost("/weChat/openIdLogin")]
  70. [AllowAnonymous]
  71. public async Task<dynamic> WechatUserLogin(WeChatUserLogin input)
  72. {
  73. var wxUser = await _weChatUserRep.GetFirstAsync(p => p.OpenId == input.OpenId);
  74. if (wxUser == null)
  75. throw Oops.Oh("微信登录");
  76. return new
  77. {
  78. wxUser.Avatar,
  79. accessToken = JWTEncryption.Encrypt(new Dictionary<string, object>
  80. {
  81. { ClaimConst.UserId, wxUser.Id },
  82. { ClaimConst.OpenId, wxUser.OpenId },
  83. { ClaimConst.NickName, wxUser.NickName },
  84. { ClaimConst.RunMode, RunModeEnum.OpenID },
  85. })
  86. };
  87. }
  88. /// <summary>
  89. /// 获取配置签名参数(wx.config)
  90. /// </summary>
  91. /// <returns></returns>
  92. [HttpPost("/weChat/genConfigPara")]
  93. public async Task<dynamic> GenConfigPara(SignatureInput input)
  94. {
  95. var resCgibinToken = await _weChatApiClient.ExecuteCgibinTokenAsync(new CgibinTokenRequest());
  96. var request = new CgibinTicketGetTicketRequest()
  97. {
  98. AccessToken = resCgibinToken.AccessToken
  99. };
  100. var response = await _weChatApiClient.ExecuteCgibinTicketGetTicketAsync(request);
  101. if (!response.IsSuccessful())
  102. throw Oops.Oh(response.ErrorMessage);
  103. return _weChatApiClient.GenerateParametersForJSSDKConfig(response.Ticket, input.Url);
  104. }
  105. }