| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115 |
- package appchat
- import (
- "encoding/json"
- "fmt"
- "github.com/silenceper/wechat/v2/util"
- )
- const (
- // 应用推送消息接口地址
- sendURL = "https://qyapi.weixin.qq.com/cgi-bin/appchat/send?access_token=%s"
- )
- type (
- // SendRequestCommon 发送应用推送消息请求公共参数
- SendRequestCommon struct {
- // 群聊id
- ChatID string `json:"chatid"`
- // 消息类型
- MsgType string `json:"msgtype"`
- // 表示是否是保密消息,0表示否,1表示是,默认0
- Safe int `json:"safe"`
- }
- // SendResponse 发送应用消息响应参数
- SendResponse struct {
- util.CommonError
- }
- // SendTextRequest 发送文本消息的请求
- SendTextRequest struct {
- *SendRequestCommon
- Text TextField `json:"text"`
- }
- // TextField 文本消息参数
- TextField struct {
- // 消息内容,最长不超过2048个字节
- Content string `json:"content"`
- }
- // SendImageRequest 发送图片消息的请求
- SendImageRequest struct {
- *SendRequestCommon
- Image ImageField `json:"image"`
- }
- // ImageField 图片消息参数
- ImageField struct {
- // 图片媒体文件id,可以调用上传临时素材接口获取
- MediaID string `json:"media_id"`
- }
- // SendVoiceRequest 发送语音消息的请求
- SendVoiceRequest struct {
- *SendRequestCommon
- Voice VoiceField `json:"voice"`
- }
- // VoiceField 语音消息参数
- VoiceField struct {
- // 语音文件id,可以调用上传临时素材接口获取
- MediaID string `json:"media_id"`
- }
- )
- // Send 发送应用消息
- // @desc 实现企业微信发送应用消息接口:https://developer.work.weixin.qq.com/document/path/90248
- func (r *Client) Send(apiName string, request interface{}) (*SendResponse, error) {
- // 获取accessToken
- accessToken, err := r.GetAccessToken()
- if err != nil {
- return nil, err
- }
- // 请求参数转 JSON 格式
- jsonData, err := json.Marshal(request)
- if err != nil {
- return nil, err
- }
- // 发起http请求
- response, err := util.HTTPPost(fmt.Sprintf(sendURL, accessToken), string(jsonData))
- if err != nil {
- return nil, err
- }
- // 按照结构体解析返回值
- result := &SendResponse{}
- if err = util.DecodeWithError(response, result, apiName); err != nil {
- return nil, err
- }
- // 返回数据
- return result, nil
- }
- // SendText 发送文本消息
- func (r *Client) SendText(request SendTextRequest) (*SendResponse, error) {
- // 发送文本消息MsgType参数固定为:text
- request.MsgType = "text"
- return r.Send("MessageSendText", request)
- }
- // SendImage 发送图片消息
- func (r *Client) SendImage(request SendImageRequest) (*SendResponse, error) {
- // 发送图片消息MsgType参数固定为:image
- request.MsgType = "image"
- return r.Send("MessageSendImage", request)
- }
- // SendVoice 发送语音消息
- func (r *Client) SendVoice(request SendVoiceRequest) (*SendResponse, error) {
- // 发送语音消息MsgType参数固定为:voice
- request.MsgType = "voice"
- return r.Send("MessageSendVoice", request)
- }
- // 以上实现了部分常用消息推送:SendText 发送文本消息、SendImage 发送图片消息、SendVoice 发送语音消息,
- // 如需扩展其他消息类型,建议按照以上格式,扩展对应消息类型的参数即可
- // 也可以直接使用Send方法,按照企业微信消息推送的接口文档传对应消息类型的参数来使用
|