This commit is contained in:
cn-hideyoshi 2024-12-11 18:52:08 +08:00
parent 1988b121ed
commit bc5999ba6f
2 changed files with 36 additions and 0 deletions

View File

@ -21,6 +21,7 @@ const (
CreateOaMenu string = "https://api.weixin.qq.com/cgi-bin/menu/create" CreateOaMenu string = "https://api.weixin.qq.com/cgi-bin/menu/create"
QueryOaMenu string = "https://api.weixin.qq.com/cgi-bin/get_current_selfmenu_info" QueryOaMenu string = "https://api.weixin.qq.com/cgi-bin/get_current_selfmenu_info"
DeleteOaMenu string = "https://api.weixin.qq.com/cgi-bin/menu/delete" DeleteOaMenu string = "https://api.weixin.qq.com/cgi-bin/menu/delete"
UploadOaMedia string = "https://api.weixin.qq.com/cgi-bin/media/upload"
) )
const ( const (

View File

@ -6,7 +6,9 @@ import (
"fmt" "fmt"
"github.com/tidwall/gjson" "github.com/tidwall/gjson"
"io" "io"
"mime/multipart"
"net/http" "net/http"
"time"
) )
type OaSdk struct { type OaSdk struct {
@ -98,6 +100,39 @@ func (o *OaSdk) GetUserInfoByOpenid(openid string) (*UserInfo, error) {
return user, nil return user, nil
} }
func (o *OaSdk) UploadFileByByte(file []byte, ext string) (string, string, error) {
body := &bytes.Buffer{}
writer := multipart.NewWriter(body)
formFile, err := writer.CreateFormFile("file", fmt.Sprintf("%d%s", time.Now().Unix(), ext))
if err != nil {
return "", "", err
}
_, err = formFile.Write(file)
if err != nil {
return "", "", err
}
err = writer.Close()
if err != nil {
return "", "", err
}
res, err := http.Post(UploadOaMedia, writer.FormDataContentType(), body)
if err != nil {
return "", "", err
}
resBody, err := io.ReadAll(res.Body)
if err != nil {
return "", "", err
}
g := gjson.ParseBytes(resBody)
errCode := g.Get("errcode").Int()
if errCode != 0 {
return "", "", fmt.Errorf("%d:%s", errCode, g.Get("errmsg").String())
}
fileType := g.Get("type").String()
fileId := g.Get("media_id").String()
return fileType, fileId, nil
}
func (o *OaSdk) CreateMenu(buttons []*OaMenuButton) error { func (o *OaSdk) CreateMenu(buttons []*OaMenuButton) error {
accessToken, err := o.getAccessToken() accessToken, err := o.getAccessToken()
if err != nil { if err != nil {