wechat.go 3.1 KB

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