wechat.go 3.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126
  1. package models
  2. import (
  3. "encoding/json"
  4. "fmt"
  5. "hongze/hongze_cygx/utils"
  6. "rdluck_tools/http"
  7. "rdluck_tools/orm"
  8. "strings"
  9. "time"
  10. )
  11. type WxLoginReq struct {
  12. Code string `description:"微信code"`
  13. }
  14. type WxToken struct {
  15. AccessToken string
  16. ExpiresIn int64
  17. Id int64
  18. }
  19. func GetWxAccessToken() (accessTokenStr string, err error) {
  20. o := orm.NewOrm()
  21. sql := `SELECT * FROM wx_token LIMIT 1`
  22. wxToken := new(WxToken)
  23. err = o.Raw(sql).QueryRow(&wxToken)
  24. if err != nil && err.Error() != utils.ErrNoRow() {
  25. return
  26. }
  27. //Token不存在
  28. if wxToken == nil {
  29. fmt.Println("wxToken is empty")
  30. accessToken, err := GetWxToken()
  31. if err != nil {
  32. return "", err
  33. }
  34. if accessToken.AccessToken != "" {
  35. expiresIn := time.Now().Add(time.Duration(accessToken.ExpiresIn) * time.Second).Unix()
  36. addSql := "insert into wx_token (access_token,expires_in) values (?,?)"
  37. _, err = o.Raw(addSql, accessToken.AccessToken, expiresIn).Exec()
  38. accessTokenStr = accessToken.AccessToken
  39. }
  40. return accessTokenStr, err
  41. } else {
  42. //判断token是否过期
  43. if time.Now().Unix() > wxToken.ExpiresIn {
  44. accessToken, err := GetWxToken()
  45. fmt.Println(accessToken)
  46. if err != nil {
  47. return "", err
  48. }
  49. if accessToken.AccessToken != "" {
  50. expiresIn := time.Now().Add(time.Duration(accessToken.ExpiresIn) * time.Second).Unix()
  51. updateSql := "update wx_token set access_token = ?,expires_in = ? "
  52. _, err = o.Raw(updateSql, accessToken.AccessToken, expiresIn).Exec()
  53. accessTokenStr = accessToken.AccessToken
  54. fmt.Println("更新 TOKEN:", err)
  55. }
  56. return accessTokenStr, err
  57. } else {
  58. return wxToken.AccessToken, nil
  59. }
  60. }
  61. return
  62. }
  63. func GetWxToken() (item *WxAccessToken, err error) {
  64. getUrl := "https://api.weixin.qq.com/cgi-bin/token?grant_type=client_credential&appid=" + utils.WxPublicAppId + "&secret=" + utils.WxPublicAppSecret
  65. result, err := http.Get(getUrl)
  66. if err != nil {
  67. return
  68. }
  69. err = json.Unmarshal(result, &item)
  70. if err != nil {
  71. fmt.Println("GetWxToken Unmarshal Err:%s", err.Error())
  72. return
  73. }
  74. if item.Errmsg != "" {
  75. }
  76. return
  77. }
  78. type WxAccessToken struct {
  79. AccessToken string `json:"access_token"`
  80. ExpiresIn int `json:"expires_in"`
  81. RefreshToken string `json:"refresh_token"`
  82. Openid string `json:"openid"`
  83. Unionid string `json:"unionid"`
  84. Scope string `json:"scope"`
  85. Errcode int `json:"errcode"`
  86. Errmsg string `json:"errmsg"`
  87. }
  88. type WxUsers struct {
  89. Total int
  90. Count int
  91. Data struct {
  92. Openid []string
  93. }
  94. NextOpenid string
  95. }
  96. func WxUsersGet() (openIdStr string) {
  97. accessToken, err := GetWxAccessToken()
  98. if err != nil {
  99. utils.FileLog.Info("GetWxAccessToken Err:%s", err.Error())
  100. return
  101. }
  102. url := "https://api.weixin.qq.com/cgi-bin/user/get?access_token=" + accessToken
  103. result, err := http.Get(url)
  104. if err != nil {
  105. utils.FileLog.Info("GetUser Err:", err.Error())
  106. return
  107. }
  108. item := new(WxUsers)
  109. err = json.Unmarshal(result, &item)
  110. if err != nil {
  111. fmt.Println("Unmarshal Err:", err.Error())
  112. return
  113. }
  114. openIdStr = strings.Join(item.Data.Openid, "','")
  115. openIdStr = "'" + openIdStr + "'"
  116. utils.FileLog.Info("openIdStr:%s", openIdStr)
  117. return
  118. }