美团联盟二维码处理

This commit is contained in:
苏尹岚
2021-04-20 16:48:56 +08:00
parent 5772bdcd1e
commit 360d8a5220
3 changed files with 24 additions and 6 deletions

View File

@@ -1962,8 +1962,20 @@ func ShareUnionLink(ctx *jxcontext.Context, jobID, linkType int) (link string, e
} }
jobOrder.JobID = job.ID jobOrder.JobID = job.ID
err = dao.GetEntity(db, jobOrder, "JobID") err = dao.GetEntity(db, jobOrder, "JobID")
if err != nil {
return link, err
}
if handler := partner.GetHandler(job.VendorID); handler != nil { if handler := partner.GetHandler(job.VendorID); handler != nil {
handler.ShareUnionLink(ctx, linkType, job.UnionActID, jobOrder.UserID) link, err = handler.ShareUnionLink(ctx, linkType, job.UnionActID, jobOrder.UserID)
if job.VendorID == model.VendorIDMTWM && linkType == partner.LinkTypeWeiXinMini {
if resBinary, _, err := jxutils.DownloadFileByURL(link + "?imageView2/1/w/100/h/100/q/75"); err == nil {
if downloadURL, err := jxutils.UploadExportContent(resBinary, utils.Int64ToStr(time.Now().Unix())+link[strings.LastIndex(link, "/")+1:len(link)]); err == nil {
if err == nil {
link = jxutils.MixWatermarkImg(downloadURL, job.UnionImg, job.UnionQrcodePosition)
}
}
}
}
} }
return link, err return link, err
} }

View File

@@ -4,14 +4,20 @@ import (
"git.rosy.net.cn/baseapi/utils" "git.rosy.net.cn/baseapi/utils"
"git.rosy.net.cn/jx-callback/business/jxstore/partner" "git.rosy.net.cn/jx-callback/business/jxstore/partner"
"git.rosy.net.cn/jx-callback/business/jxutils/jxcontext" "git.rosy.net.cn/jx-callback/business/jxutils/jxcontext"
"git.rosy.net.cn/jx-callback/globals/api"
"strings" "strings"
) )
func (s *UnionHandler) ShareUnionLink(ctx *jxcontext.Context, linkType, unionActID int, userID string) (link string, err error) { func (s *UnionHandler) ShareUnionLink(ctx *jxcontext.Context, linkType, unionActID int, userID string) (link string, err error) {
if linkType == partner.LinkTypeWeiXinMini { if linkType == partner.LinkTypeWeiXinMini {
//return api.MtUnionAPI.GenerateLink(unionActID, userID) if qrCode, err := api.MtUnionAPI.MiniCode(unionActID, userID); err == nil {
if qrCode != "" {
return qrCode, err
}
}
return
} else { } else {
return api.MtUnionAPI.GenerateLink(unionActID, linkType, userID)
} }
return link, err return link, err
} }

View File

@@ -821,13 +821,13 @@ func PKCS5UnPadding(origData []byte) []byte {
} }
//合成水印图 //合成水印图
func MixWatermarkImg(imgWatermark, img string) (imgMix string) { func MixWatermarkImg(imgWatermark, img, positon string) (imgMix string) {
baseURL := base64.URLEncoding.EncodeToString([]byte(imgWatermark)) baseURL := base64.URLEncoding.EncodeToString([]byte(imgWatermark))
var imgUrl string var imgUrl string
if strings.Contains(img, "?") { if strings.Contains(img, "?") {
imgUrl = img + "/imageView2/0/q/75|watermark/1/image/" + baseURL + "/dissolve/100/gravity/South/dx/0/dy/0" imgUrl = img + "/imageView2/0/q/75|watermark/1/image/" + baseURL + "/dissolve/100/gravity/" + positon + "/dx/0/dy/0"
} else { } else {
imgUrl = img + "?imageView2/0/q/75|watermark/1/image/" + baseURL + "/dissolve/100/gravity/South/dx/0/dy/0" imgUrl = img + "?imageView2/0/q/75|watermark/1/image/" + baseURL + "/dissolve/100/gravity/" + positon + "/dx/0/dy/0"
} }
if resBinary, _, err := DownloadFileByURL(imgUrl); err == nil { if resBinary, _, err := DownloadFileByURL(imgUrl); err == nil {
if downloadURL, err := UploadExportContent(resBinary, utils.Int64ToStr(time.Now().Unix())+img[strings.LastIndex(img, "/")+1:len(img)]); err == nil { if downloadURL, err := UploadExportContent(resBinary, utils.Int64ToStr(time.Now().Unix())+img[strings.LastIndex(img, "/")+1:len(img)]); err == nil {