webpage.go 2.2KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071
  1. package webpage
  2. // 代公众号发起网页授权
  3. import (
  4. "encoding/json"
  5. "errors"
  6. "net/url"
  7. "strings"
  8. "gitee.com/yansen_zh/wxcomponent/config"
  9. wxerr "gitee.com/yansen_zh/wxcomponent/errors"
  10. "gitee.com/yansen_zh/wxcomponent/utils/request"
  11. )
  12. // GetOAuthCodeLink 代公众号发起网页授权, 构造授权链接
  13. // redirectURI 必须是未经编码的原始网址字符串
  14. func GetOAuthCodeLink(appID, redirectURI, state string, scopes ...string) string {
  15. params := url.Values{}
  16. params.Set("appid", appID)
  17. params.Set("redirect_uri", redirectURI)
  18. params.Set("response_type", "code")
  19. params.Set("scope", strings.Join(scopes, ","))
  20. params.Set("state", state)
  21. params.Set("component_appid", config.GetAppID())
  22. return "https://open.weixin.qq.com/connect/oauth2/authorize?" + params.Encode()
  23. }
  24. // MpOAuthAccessTokenResult 网页授权, 通过 code 换取 access_token 返回值
  25. type MpOAuthAccessTokenResult struct {
  26. wxerr.Error
  27. // AccessToken 接口调用凭证
  28. AccessToken string `json:"access_token"`
  29. // ExpiresIn access_token 接口调用凭证超时时间,单位(秒)
  30. ExpiresIn int `json:"expires_in"`
  31. // RefreshToken 用户刷新 access_token
  32. RefreshToken string `json:"refresh_token"`
  33. // Openid 授权用户唯一标识
  34. OpenID string `json:"openid"`
  35. // Scope 用户授权的作用域,使用逗号(,)分隔
  36. Scope string `json:"scope"`
  37. }
  38. const apiOAuthAccessToken = "https://api.weixin.qq.com/sns/oauth2/component/access_token"
  39. // GetOAuthAccessToken 网页授权, 通过 code 换取 access_token
  40. func GetOAuthAccessToken(appID, code string) (*MpOAuthAccessTokenResult, error) {
  41. if appID == "" || code == "" {
  42. return nil, errors.New("获取网页授权Token appID 或者 code 不能为空")
  43. }
  44. param := url.Values{}
  45. param.Set("appid", appID)
  46. param.Set("code", code)
  47. param.Set("grant_type", "authorization_code")
  48. param.Set("component_appid", config.GetAppID())
  49. param.Set("component_access_token", config.GetAccessToken())
  50. resp, e2 := request.GetJSON(apiOAuthAccessToken, &param)
  51. if e2 != nil {
  52. return nil, e2
  53. }
  54. result := MpOAuthAccessTokenResult{}
  55. if err := json.Unmarshal(resp, &result); err != nil {
  56. return nil, err
  57. }
  58. return &result, nil
  59. }