|
@@ -71,6 +71,11 @@ func SendWxTemplateMsg(sendInfo *models.SendWxTemplate) (err error) {
|
|
|
sendData["keyword4"] = map[string]interface{}{"value": sendInfo.Keyword4, "color": "#173177"}
|
|
|
uniqueCodeStr += sendInfo.Keyword4
|
|
|
}
|
|
|
+
|
|
|
+ if sendInfo.Keyword5 != "" {
|
|
|
+ sendData["keyword5"] = map[string]interface{}{"value": sendInfo.Keyword5, "color": "#173177"}
|
|
|
+ uniqueCodeStr += sendInfo.Keyword5
|
|
|
+ }
|
|
|
if sendInfo.Productname != "" {
|
|
|
sendData["productname"] = map[string]interface{}{"value": sendInfo.Productname, "color": "#173177"}
|
|
|
uniqueCodeStr += sendInfo.Productname
|
|
@@ -102,7 +107,7 @@ func SendWxTemplateMsg(sendInfo *models.SendWxTemplate) (err error) {
|
|
|
xcxAppId = utils.WxCygxAppId
|
|
|
} else {
|
|
|
err = errors.New("无效的微信小程序跳转方式:RedirectTarget" + strconv.Itoa(sendInfo.RedirectTarget))
|
|
|
- return err
|
|
|
+ return err
|
|
|
}
|
|
|
sendMap["miniprogram"] = map[string]interface{}{"appid": xcxAppId, "pagepath": sendInfo.RedirectUrl}
|
|
|
}
|
|
@@ -178,7 +183,7 @@ func toSendTemplateMsg(wxAppId string, data []byte, resource string, sendType in
|
|
|
|
|
|
accessToken, err, errMsg = getWxAccessToken(wxAppId)
|
|
|
if err != nil {
|
|
|
- utils.FileLog.Info(fmt.Sprintf("获取Token失败,err:%s,errMsg:%s",err.Error(), errMsg))
|
|
|
+ utils.FileLog.Info(fmt.Sprintf("获取Token失败,err:%s,errMsg:%s", err.Error(), errMsg))
|
|
|
return
|
|
|
}
|
|
|
|
|
@@ -225,14 +230,14 @@ func toSendTemplateMsg(wxAppId string, data []byte, resource string, sendType in
|
|
|
}
|
|
|
|
|
|
//accessToken过期
|
|
|
- if templateResponse.Errcode == 40001{
|
|
|
+ if templateResponse.Errcode == 40001 {
|
|
|
//强刷token并重新推送
|
|
|
- accessToken,err,errMsg = refreshWxAccessToken(wxAppId)
|
|
|
- if err != nil{
|
|
|
+ accessToken, err, errMsg = refreshWxAccessToken(wxAppId)
|
|
|
+ if err != nil {
|
|
|
utils.FileLog.Info(fmt.Sprintf("refreshWxAccessToken Err:%s", err.Error()))
|
|
|
return err
|
|
|
}
|
|
|
- return toSendTemplateMsg(wxAppId,data, resource, sendType, openId, uniqueCode)
|
|
|
+ return toSendTemplateMsg(wxAppId, data, resource, sendType, openId, uniqueCode)
|
|
|
}
|
|
|
|
|
|
//模板消息发送超过当日10万次限制错误处理
|
|
@@ -284,9 +289,9 @@ func toSendTemplateMsg(wxAppId string, data []byte, resource string, sendType in
|
|
|
}
|
|
|
|
|
|
// getWxAccessToken 获取微信token
|
|
|
-func getWxAccessToken(wxAppId string)(accessToken string,err error,errMsg string){
|
|
|
+func getWxAccessToken(wxAppId string) (accessToken string, err error, errMsg string) {
|
|
|
redisKey := getRedisKeyByAppid(wxAppId)
|
|
|
- if redisKey == ``{
|
|
|
+ if redisKey == `` {
|
|
|
errMsg = "未配置缓存key"
|
|
|
err = errors.New(errMsg)
|
|
|
return
|
|
@@ -301,7 +306,7 @@ func getWxAccessToken(wxAppId string)(accessToken string,err error,errMsg string
|
|
|
// return
|
|
|
//}
|
|
|
//取到数据后就直接返回了,没有后续了
|
|
|
- if accessToken != ""{
|
|
|
+ if accessToken != "" {
|
|
|
return
|
|
|
}
|
|
|
|
|
@@ -310,15 +315,15 @@ func getWxAccessToken(wxAppId string)(accessToken string,err error,errMsg string
|
|
|
}
|
|
|
|
|
|
// refreshWxAccessToken 强制刷新微信token
|
|
|
-func refreshWxAccessToken(wxAppId string)(accessToken string,err error,errMsg string){
|
|
|
- fmt.Println("强制刷新"+wxAppId+"微信token")
|
|
|
+func refreshWxAccessToken(wxAppId string) (accessToken string, err error, errMsg string) {
|
|
|
+ fmt.Println("强制刷新" + wxAppId + "微信token")
|
|
|
defer func() {
|
|
|
- if errMsg !=``{
|
|
|
- utils.FileLog.Info(fmt.Sprintf("强制刷新%s微信token异常:%s", wxAppId,errMsg))
|
|
|
+ if errMsg != `` {
|
|
|
+ utils.FileLog.Info(fmt.Sprintf("强制刷新%s微信token异常:%s", wxAppId, errMsg))
|
|
|
}
|
|
|
}()
|
|
|
redisKey := getRedisKeyByAppid(wxAppId)
|
|
|
- if redisKey == ``{
|
|
|
+ if redisKey == `` {
|
|
|
errMsg = "未配置缓存key"
|
|
|
err = errors.New(errMsg)
|
|
|
return
|
|
@@ -327,7 +332,7 @@ func refreshWxAccessToken(wxAppId string)(accessToken string,err error,errMsg st
|
|
|
wxAppSecret, ok := utils.WxAppList[wxAppId]
|
|
|
if !ok {
|
|
|
err = errors.New("缺少密钥信息")
|
|
|
- utils.FileLog.Info(fmt.Sprintf("获取Token失败, errMsg:%s",err.Error()))
|
|
|
+ utils.FileLog.Info(fmt.Sprintf("获取Token失败, errMsg:%s", err.Error()))
|
|
|
return
|
|
|
}
|
|
|
|
|
@@ -346,22 +351,21 @@ func refreshWxAccessToken(wxAppId string)(accessToken string,err error,errMsg st
|
|
|
return
|
|
|
}
|
|
|
|
|
|
-
|
|
|
accessToken = wxAccessToken.AccessToken
|
|
|
//如果是弘则研究的appid,那么需要更新mysql的accessToken
|
|
|
- if wxAppId == utils.WxAppId{
|
|
|
+ if wxAppId == utils.WxAppId {
|
|
|
expiresIn := time.Now().Add(time.Duration(wxAccessToken.ExpiresIn) * time.Second).Unix()
|
|
|
- err = models.ModifyAccessToken(wxAccessToken.AccessToken,expiresIn)
|
|
|
- if err!=nil{
|
|
|
+ err = models.ModifyAccessToken(wxAccessToken.AccessToken, expiresIn)
|
|
|
+ if err != nil {
|
|
|
errMsg = "更新mysql中的accessToken失败 Err:" + err.Error()
|
|
|
return
|
|
|
}
|
|
|
}
|
|
|
|
|
|
//更新redis的accessToken(过期时间提前十分钟)
|
|
|
- redisTimeExpire := time.Duration(wxAccessToken.ExpiresIn - 600) * time.Second
|
|
|
- err = utils.Rc.Put(redisKey,accessToken,redisTimeExpire)
|
|
|
- if err!=nil{
|
|
|
+ redisTimeExpire := time.Duration(wxAccessToken.ExpiresIn-600) * time.Second
|
|
|
+ err = utils.Rc.Put(redisKey, accessToken, redisTimeExpire)
|
|
|
+ if err != nil {
|
|
|
errMsg = "更新redis中的accessToken失败 Err:" + err.Error()
|
|
|
return
|
|
|
}
|
|
@@ -372,7 +376,7 @@ func refreshWxAccessToken(wxAppId string)(accessToken string,err error,errMsg st
|
|
|
// WxGetRedisAccessToken 从redis中获取token
|
|
|
func WxGetRedisAccessToken(wxAppId, wxAppSecret string) (accessToken string, err error) {
|
|
|
//从redis中获取token校验验证码
|
|
|
- accessToken, err = utils.Rc.RedisString(utils.HZ_ADMIN_WX_ACCESS_TOEKN+wxAppId)
|
|
|
+ accessToken, err = utils.Rc.RedisString(utils.HZ_ADMIN_WX_ACCESS_TOEKN + wxAppId)
|
|
|
if err != nil {
|
|
|
err = nil
|
|
|
token, tErr := models.GetWxToken(wxAppId, wxAppSecret)
|
|
@@ -384,7 +388,7 @@ func WxGetRedisAccessToken(wxAppId, wxAppSecret string) (accessToken string, err
|
|
|
return "", err
|
|
|
}
|
|
|
//更新redis的accessToken(过期时间提前十分钟)
|
|
|
- redisTimeExpire := time.Duration(token.ExpiresIn - 600) * time.Second
|
|
|
+ redisTimeExpire := time.Duration(token.ExpiresIn-600) * time.Second
|
|
|
err = utils.Rc.Put(utils.HZ_ADMIN_WX_ACCESS_TOEKN+wxAppId, token.AccessToken, redisTimeExpire)
|
|
|
if err != nil {
|
|
|
err = errors.New("保存access_token失败 " + err.Error())
|
|
@@ -402,7 +406,7 @@ func getRedisKeyByAppid(wxAppId string) (redisKey string) {
|
|
|
case utils.WxAppId:
|
|
|
redisKey = utils.CACHE_WX_ACCESS_TOKEN_HZ
|
|
|
case utils.AdminWxAppId:
|
|
|
- redisKey = utils.HZ_ADMIN_WX_ACCESS_TOEKN+wxAppId
|
|
|
+ redisKey = utils.HZ_ADMIN_WX_ACCESS_TOEKN + wxAppId
|
|
|
}
|
|
|
return redisKey
|
|
|
-}
|
|
|
+}
|