wechat.go 3.0 KB

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