0

0

微信公众平台开发(89) 高级群发接口_PHP教程

php中文网

php中文网

发布时间:2016-07-13 10:31:32

|

1206人浏览过

|

来源于php中文网

原创

在这篇微信公众平台高级接口开发教程中,我们将介绍如何开发高级群发接口功能。

本文分为以下四个部分:

 

一、准备群发内容

群发内容可以是文本、图片、语音、视频、图文。群发文本只需要文本内容,其他内容需要获得相应的media_id。

1. 文本内容

文本内容就是一段文字,比如:""

立即学习PHP免费学习笔记(深入)”;

2. 图片、语音、视频

要求如下:

  • Ÿ 图片(image): 128K,支持JPG格式
  • Ÿ 语音(voice):256K,播放长度不超过60s,支持AMR\MP3格式
  • Ÿ 视频(video):1MB,支持MP4格式

准备好以后,需要使用上传下载多媒体文件接口将其上传到微信服务器,获得
上传的开发方法,可以参考本博客的第80篇教程 

3. 图文

首先要准备缩略图,要求如下:

  • 缩略图(thumb):64KB,支持JPG格式

同样的,使用上传下载多媒体文件接口,上传到微信服务器后,得到缩略图的media_id,
然后需要使用接口将其上传到微信服务器,接口为

要POST提交的数据示例如下:

<span>"articles"<span :>"thumb_media_id":"qI6_Ze_6PtV7svjolgs-rN6stStuHIjs9_DidOHaj0Q-mwvBelOXCFZiq2OsIU-p"<span>"author":"xxx"<span>"title":"Happy Day"<span>"content_source_url":"www.qq.com"<span>"content":"content"<span>"digest":"digest"<span>"thumb_media_id":"qI6_Ze_6PtV7svjolgs-rN6stStuHIjs9_DidOHaj0Q-mwvBelOXCFZiq2OsIU-p"<span>"author":"xxx"<span>"title":"Happy Day"<span>"content_source_url":"www.qq.com"<span>"content":"content"<span>"digest":"digest"<span></span></span></span></span></span></span></span></span></span></span></span></span></span></span>

参数说明如下:

参数 是否必须 说明
Articles 图文消息,一个图文消息支持1到10条图文
thumb_media_id 图文消息缩略图的media_id,可以在基础支持-上传多媒体文件接口中获得
author 图文消息的作者
title 图文消息的标题
content_source_url 在图文消息页面点击“阅读原文”后的页面
content 图文消息页面的内容,支持HTML标签
digest 图文消息的描述

 根据上述POST结构,定义图文数组如下:

<span>[] = <span array>("thumb_media_id"=><span>,
                "author"=>"",
                "title"=>"微信公众平台开发",
                "content_source_url" =>"",
                "content" =>"",
                "digest" =>""<span><span>[] = <span array>("thumb_media_id"=><span>,
                "author"=>"方倍工作室",
                "title"=>"微信公众平台开发入门教程",
                "content_source_url" =>"http://m.cnblogs.com/99079/3153567.html?full=1",
                "content" =>"<span sdk>",
                "digest" =>"微信公众平台开发经典的入门教程,学习微信公众平台开发必经之路!"<span><span>[] = <span array>("thumb_media_id"=><span>,
                "author"=>"方倍工作室",
                "title"=>"微信公众平台开发最佳实践",
                "content_source_url" =>"http://m.cnblogs.com/?u=txw1958",
                "content" =>"<p>本书共分10章,案例程序采用广泛流行的PHP、MySQL、XML、CSS、JavaScript、HTML5等程序语言及数据库实现。系统完整地介绍微信公众平台基础接口、自定义菜单、高级接口、微信支付、分享转发等所有相关技术,以生活类、娱乐类、企业类微信开发为切入点,讲解了30多个功能或应用案例。<br>本书按照从简单到复杂,从基础到实践的方式编排,在讲解过程中注重将原理和实践相结合。初学者可以在了解PHP和MySQL语法之后,从头至尾学习,对于其中难以理解的部分可以查阅相关资料,针对企业功能类的开发还需要具有一定的JavaScript、CSS、HTML等编程基础。<br>本书可以作为微信公众平台开发的教程。对于移动互联网及微信公众平台的相关从业人员,本书也具有极大的参考价值。</p>",
                "digest" =>"微信公众平台开发含金量最高的书籍"<span></span></span></span></span></span></span></span></span></span></span></span></span></span>

上传图文消息素材的代码则实现如下:

 

上传成功后,返回如下,将得到图文消息的media_id

<span>"type":"news",
    "media_id":"CsEf3ldqkAYJAU6EJeIkStVDSvffUJ54vqbThMgplD-VJXXof6ctX5fI6-aYyUiQ",
    "created_at":1391857799<span></span></span>

 

二、选择群发对象

群发对象可以是用户组,也可以是OpenID列表。

1.用户组

获得用户分组,需要使用高级接口中的查询所有分组接口,获得相应的group_id,
开发方法,可以参考本博客的第88篇教程 微信公众平台开发(88) 用户分组接口

2.OpenID列表

OpenID列表,是使用高级接口中的获取关注者列表接口来实现的。
开发方法,可以参考本博客的第87篇教程 微信公众平台开发(87) 获取关注者列表

 

三、执行群发

由于群发对象的不同,执行群发也有不同的方式。

1. 对用户组群发

对用户组群发的接口如下:

https://api.weixin.qq.com/cgi-bin/message/mass/sendall?access_token=ACCESS_TOKEN

要POST的内容按内容不同组成也不一样。

文本:

<span>"filter"<span :>"group_id":"2"<span>"text"<span :>"content":"CONTENT"<span>"msgtype":"text"<span></span></span></span></span></span></span>

淘特微信宝
淘特微信宝

淘特微信宝是淘特CMS团队最新研制的微信公众平台管理工具包,该产品提供一个后台管理多个微信公众号功能,可以一站式管理多个微信公众号的自动回复消息、自定义菜单等功能,通过后台可视化操作免去微信接口程序开发的繁锁工作,令不懂程序的人也能灵活管理微信公众号。

下载
<span>"filter"<span :>"group_id":"2"<span>"voice"<span :>"media_id":"123dsdajkasd231jhksad"<span>"msgtype":"voice"<span></span></span></span></span></span></span>

<span>"filter"<span :>"group_id":"2"<span>"image"<span :>"media_id":"123dsdajkasd231jhksad"<span>"msgtype":"image"<span></span></span></span></span></span></span>

<span>"filter"<span :>"group_id":"2"<span>"mpvideo"<span :>"media_id":"IhdaAQXuvJtGzwwc0abfXnzeezfO0NgPK6AQYShD8RQYMTtfzbLdBIQkQziv2XJc"<span>"msgtype":"mpvideo"<span></span></span></span></span></span></span>

<span>"filter"<span :>"group_id":"2"<span>"mpnews"<span :>"media_id":"123dsdajkasd231jhksad"<span>"msgtype":"mpnews"<span></span></span></span></span></span></span>

相关参数说明如下:

参数 是否必须 说明
filter 用于设定图文消息的接收者
group_id 群发到的分组的group_id
mpnews 用于设定即将发送的图文消息
media_id 用于群发的消息的media_id
msgtype 群发的消息类型,图文消息为mpnews,文本消息为text,语音为voice,音乐为music,图片为image,视频为video
title 消息的标题
description 消息的描述
thumb_media_id 视频缩略图的媒体ID

其接口实现代码如下所示:

返回结果如下:

<span array>(3<span>"errcode"]=><span int>0<span>"errmsg"]=>
  <span string>(27) "send job submission success"<span>"msg_id"]=>
  <span float>(2347614963<span></span></span></span></span></span></span></span></span>

参数说明

参数 说明
type 媒体文件类型,分别有图片(image)、语音(voice)、视频(video)和缩略图(thumb),图文消息为news
errcode 错误码
errmsg 错误信息
msg_id 消息ID

下面是向用户组发送图文消息的效果,分别是接收到图文消息,查看图文消息内容后的效果,

2.对OpenID列表群发

接口如下:

POST数据示例如下:
文本:

<span>"touser":<span>"oR5Gjjl_eiZoUpGozMo7dbBJ362A", 
        "oR5Gjjo5rXlMUocSEXKT7Q5RQ63Q"<span>, 
    "msgtype": "text", 
    "text":<span>"content": "hello from boxer."<span></span></span></span></span></span>

语音:

<span>"touser":<span>"OPENID1",
        "OPENID2"<span>,
   "voice":<span>"media_id":"mLxl6paC7z2Tl-NJT64yzJve8T9c8u9K2x-Ai6Ujd4lIH9IBuF6-2r66mamn_gIT"<span>,
   "msgtype":"voice"<span></span></span></span></span></span></span>

图片:

<span>"touser":<span>"OPENID1",
    "OPENID2"<span>,
   "image":<span>"media_id":"BTgN0opcW3Y5zV_ZebbsD3NFKRWf6cb7OPswPi9Q83fOJHK2P67dzxn11Cp7THat"<span>,
   "msgtype":"image"<span></span></span></span></span></span></span>

<span>"touser":<span>"OPENID1",
        "OPENID2"<span>,
   "video":<span>"media_id":"123dsdajkasd231jhksad",
      "title":"TITLE",
      "description":"DESCRIPTION"<span>,
   "msgtype":"video"<span></span></span></span></span></span></span>

图文消息(注意图文消息的media_id需要通过上述方法来得到):

<span>"touser":<span>"OPENID1",
        "OPENID2"<span>,
   "mpnews":<span>"media_id":"123dsdajkasd231jhksad"<span>,
   "msgtype":"mpnews"<span></span></span></span></span></span></span>

参数列表

参数 是否必须 说明
touser 填写图文消息的接收者,一串OpenID列表,OpenID最少个,最多10000个
mpnews 用于设定即将发送的图文消息
media_id 用于群发的图文消息的media_id
msgtype 群发的消息类型,图文消息为mpnews,文本消息为text,语音为voice,音乐为music,图片为image,视频为video
title 消息的标题
description 消息的描述
thumb_media_id 视频缩略图的媒体ID

返回数据示例(正确时的JSON返回结果):

<span>"errcode":0,
    "errmsg":"send job submission success",
    "msg_id":<span>2347614964</span><span></span></span>

 

四、接收群发结果   

1. 设置公众号助手

为了能接收群发结果,需要设置公众号助手,结果将推送到绑定的个人微信账号上。其设置如下

2. 接收结果事件

群发任务提交后,群发任务可能在一定时间后才完成,因此,群发接口调用时,仅会给出群发任务是否提交成功的提示,若群发任务提交成功,则在群发任务结束时,会向开发者在公众平台填写的开发者URL(callback URL)推送事件。

推送的XML结构如下(发送成功时):

<span><span xml><span>
    <span><span tousername><span><span><span gh_3e8adccde292><span><span><span tousername><span>
    <span><span fromusername><span><span><span or5gjjl_eizoupgozmo7dbbj362a><span><span><span fromusername><span>
    <span><span createtime><span>1394524295<span><span createtime><span>
    <span><span msgtype><span><span><span event><span><span><span msgtype><span>
    <span><span event><span><span><span masssendjobfinish><span><span><span event><span>
    <span><span msgid><span>1988<span><span msgid><span>
    <span><span status><span><span><span sendsuccess><span><span><span status><span>
    <span><span totalcount><span>100<span><span totalcount><span>
    <span><span filtercount><span>80<span><span filtercount><span>
    <span><span sentcount><span>75<span><span sentcount><span>
    <span><span errorcount><span>5<span><span errorcount><span>
<span><span xml><span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span>
参数 说明
ToUserName 公众号的微信号
FromUserName 公众号群发助手的微信号,为mphelper
CreateTime 创建时间的时间戳
MsgType 消息类型,此处为event
Event 事件信息,此处为MASSSENDJOBFINISH
MsgID 群发的消息ID
Status 群发的结构,为“send success”或“send fail”或“err(num)”。但send success时,也有可能因用户拒收公众号的消息、系统错误等原因造成少量用户接收失败。err(num)是审核失败的具体原因,可能的情况如下:

err(10001), //涉嫌广告 err(20001), //涉嫌政治 err(20004), //涉嫌社会 err(20002), //涉嫌色情 err(20006), //涉嫌违法犯罪 err(20008), //涉嫌欺诈 err(20013), //涉嫌版权 err(22000), //涉嫌互推(互相宣传) err(21000), //涉嫌其他

TotalCount group_id下粉丝数;或者openid_list中的粉丝数
FilterCount 过滤(过滤是指特定地区、性别的过滤、用户设置拒收的过滤,用户接收已超4条的过滤)后,准备发送的粉丝数,原则上,FilterCount = SentCount + ErrorCount
SentCount 发送成功的粉丝数
ErrorCount 发送失败的粉丝数

从上可以看出,这其实是公众号群发助手模拟向公众号发送消息,那么群发结果也是返回给公众号助手。

在微信公众平台PHP SDK中增加该事件消息的处理结果如下:

<span private> <span function> receiveEvent(<span><span><span> = ""<span><span switch> (<span>-><span event><span case> "subscribe":
            <span> = "欢迎关注方倍工作室"<span><span break><span><span case> "MASSSENDJOBFINISH":
            <span> = "消息ID:".<span>->MsgID.
                       "\n结果:".<span>->Status.
                       "\n粉丝数:".<span>->TotalCount.
                       "\n过滤:".<span>->FilterCount.
                       "\n发送成功:".<span>->SentCount.
                       "\n发送失败:".<span>-><span errorcount><span break><span><span default>:
            <span break><span><span> = <span>->transmitText(<span>, <span><span><span return> <span><span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span>

 

====================================================================

方倍工作室微信公众平台账号关注方法:
1. 微信通讯录-添加朋友-查找公众号-搜索“方倍工作室”
2. 微信通讯录-添加朋友-搜号码-输入“pondbaystudio”
3. 使用微信扫描下面的二维码

 

 

www.bkjia.comtruehttp://www.bkjia.com/PHPjc/763354.htmlTechArticle在这篇微信公众平台高级接口开发教程中,我们将介绍如何开发高级群发接口功能。 本文分为以下四个部分: 一、准备群发内容 群发内容...

相关文章

微信app下载
微信app下载

微信是一款手机通信软件,支持通过手机网络发送语音短信、视频、图片和文字。微信可以单聊及群聊,还能根据地理位置找到附近的人,带给大家全新的移动沟通体验,有需要的小伙伴快来保存下载体验吧!

下载

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法
pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法

本专题系统整理pixiv网页版官网入口及登录访问方式,涵盖官网登录页面直达路径、在线阅读入口及快速进入方法说明,帮助用户高效找到pixiv官方网站,实现便捷、安全的网页端浏览与账号登录体验。

1142

2026.02.13

微博网页版主页入口与登录指南_官方网页端快速访问方法
微博网页版主页入口与登录指南_官方网页端快速访问方法

本专题系统整理微博网页版官方入口及网页端登录方式,涵盖首页直达地址、账号登录流程与常见访问问题说明,帮助用户快速找到微博官网主页,实现便捷、安全的网页端登录与内容浏览体验。

371

2026.02.13

Flutter跨平台开发与状态管理实战
Flutter跨平台开发与状态管理实战

本专题围绕Flutter框架展开,系统讲解跨平台UI构建原理与状态管理方案。内容涵盖Widget生命周期、路由管理、Provider与Bloc状态管理模式、网络请求封装及性能优化技巧。通过实战项目演示,帮助开发者构建流畅、可维护的跨平台移动应用。

245

2026.02.13

TypeScript工程化开发与Vite构建优化实践
TypeScript工程化开发与Vite构建优化实践

本专题面向前端开发者,深入讲解 TypeScript 类型系统与大型项目结构设计方法,并结合 Vite 构建工具优化前端工程化流程。内容包括模块化设计、类型声明管理、代码分割、热更新原理以及构建性能调优。通过完整项目示例,帮助开发者提升代码可维护性与开发效率。

37

2026.02.13

Redis高可用架构与分布式缓存实战
Redis高可用架构与分布式缓存实战

本专题围绕 Redis 在高并发系统中的应用展开,系统讲解主从复制、哨兵机制、Cluster 集群模式及数据分片原理。内容涵盖缓存穿透与雪崩解决方案、分布式锁实现、热点数据优化及持久化策略。通过真实业务场景演示,帮助开发者构建高可用、可扩展的分布式缓存系统。

114

2026.02.13

c语言 数据类型
c语言 数据类型

本专题整合了c语言数据类型相关内容,阅读专题下面的文章了解更多详细内容。

77

2026.02.12

雨课堂网页版登录入口与使用指南_官方在线教学平台访问方法
雨课堂网页版登录入口与使用指南_官方在线教学平台访问方法

本专题系统整理雨课堂网页版官方入口及在线登录方式,涵盖账号登录流程、官方直连入口及平台访问方法说明,帮助师生用户快速进入雨课堂在线教学平台,实现便捷、高效的课程学习与教学管理体验。

17

2026.02.12

豆包AI网页版入口与智能创作指南_官方在线写作与图片生成使用方法
豆包AI网页版入口与智能创作指南_官方在线写作与图片生成使用方法

本专题汇总豆包AI官方网页版入口及在线使用方式,涵盖智能写作工具、图片生成体验入口和官网登录方法,帮助用户快速直达豆包AI平台,高效完成文本创作与AI生图任务,实现便捷智能创作体验。

863

2026.02.12

PostgreSQL性能优化与索引调优实战
PostgreSQL性能优化与索引调优实战

本专题面向后端开发与数据库工程师,深入讲解 PostgreSQL 查询优化原理与索引机制。内容包括执行计划分析、常见索引类型对比、慢查询优化策略、事务隔离级别以及高并发场景下的性能调优技巧。通过实战案例解析,帮助开发者提升数据库响应速度与系统稳定性。

123

2026.02.12

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
React 路由精讲视频教程
React 路由精讲视频教程

共10课时 | 2.3万人学习

最新Python教程 从入门到精通
最新Python教程 从入门到精通

共4课时 | 22.4万人学习

Rust 教程
Rust 教程

共28课时 | 6.2万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号