博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
php 微信公众平台开发之微信群发信息
阅读量:5091 次
发布时间:2019-06-13

本文共 6979 字,大约阅读时间需要 23 分钟。

这篇文章主要为大家详细介绍了php微信公众平台开发之微信群发信息,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

1、目的

  完成在微信公众号中群发消息。这里只是完成简单的文字发送。也可以发送语音图片等,只是发送数据格式不同而已,下面有链接,可以查询数据类型的数据发送格式。

2、群发短信的流程

获取测试公众账号(有账号的可以不用测试账号,不过正式的账号限制比较多)用户关注上面的公众账号通过appid和appsecret获取我们的access_token通过access_token群发短信

3、获取测试公众账号 + 关注公众号

1)、公众测试账号获取

  访问上面的连接,选择“接口测试号申请”获得直接打开http://mp.weixin.qq.com/debug/cgi-bin/sandboxinfo?action=showinfo&t=sandbox/index通过微信客户端扫码登录即可登录。

  登录完即可获取到一个测试公众账号的信息。主要有appId和appsecret两个参数,这将唯一标示一个公众号,并且需要将他们作为参数获取用户的信息。、

2)、配置接口信息

这一步可以参照,该页提供一个php的实例下载,很简单基本上修改一下自定义的TOKEN就好了,然后把验证页面放到自己的服务器上。

这里我提供我做的一个例子:

准备资源:

域名+空间(我的是sae空间+万网域名)、仅作验证的php文件

域名指向的空间根目录我创建了一个wx_sample.php

wx_sample.php

 

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
<?php
/**
* wechat php test
*/
 
//define your token
define(
"TOKEN"
,
"weixin"
);
$wechatObj
=
new
wechatCallbackapiTest();
$wechatObj
->valid();
 
class
wechatCallbackapiTest
{
public
function
valid()
{
$echoStr
=
$_GET
[
"echostr"
];
 
//valid signature , option
if
(
$this
->checkSignature()){
echo
$echoStr
;
exit
;
}
}
 
public
function
responseMsg()
{
//get post data, May be due to the different environments
$postStr
=
$GLOBALS
[
"HTTP_RAW_POST_DATA"
];
 
//extract post data
if
(!
empty
(
$postStr
)){
/* libxml_disable_entity_loader is to prevent XML eXternal Entity Injection,
the best way is to check the validity of xml by yourself */
libxml_disable_entity_loader(true);
$postObj
= simplexml_load_string(
$postStr
,
'SimpleXMLElement'
, LIBXML_NOCDATA);
$fromUsername
=
$postObj
->FromUserName;
$toUsername
=
$postObj
->ToUserName;
$keyword
= trim(
$postObj
->Content);
$time
= time();
$textTpl
= "<xml>
<ToUserName><![CDATA[%s]]></ToUserName>
<FromUserName><![CDATA[%s]]></FromUserName>
<CreateTime>%s</CreateTime>
<MsgType><![CDATA[%s]]></MsgType>
<Content><![CDATA[%s]]></Content>
<FuncFlag>0</FuncFlag>
</xml>";
if
(!
empty
(
$keyword
))
{
$msgType
=
"text"
;
$contentStr
=
"Welcome to wechat world!"
;
$resultStr
= sprintf(
$textTpl
,
$fromUsername
,
$toUsername
,
$time
,
$msgType
,
$contentStr
);
echo
$resultStr
;
}
else
{
echo
"Input something..."
;
}
 
}
else
{
echo
""
;
exit
;
}
}
 
private
function
checkSignature()
{
// you must define TOKEN by yourself
if
(!defined(
"TOKEN"
)) {
throw
new
Exception(
'TOKEN is not defined!'
);
}
 
$signature
=
$_GET
[
"signature"
];
$timestamp
=
$_GET
[
"timestamp"
];
$nonce
=
$_GET
[
"nonce"
];
 
$token
= TOKEN;
$tmpArr
=
array
(
$token
,
$timestamp
,
$nonce
);
// use SORT_STRING rule
sort(
$tmpArr
, SORT_STRING);
$tmpStr
= implode(
$tmpArr
);
$tmpStr
= sha1(
$tmpStr
);
 
if
(
$tmpStr
==
$signature
){
return
true;
}
else
{
return
false;
}
 
}
}
 
?>

  然后填写配置信息Token (一定要与上面的wx_sample.php中的token一致)、URL(wx_sample.php的地址)

然后提交就可以了

如果提示失败,请检查Token与URL【如果是自己的域名和空间,请备案; 百度sae、新浪sae的需要自己申请而且认证通过(就是自己拍一个手握证件照上传,很简单的 最短2天就o了),这一步必须】

3)配置JS接口安全域名

  填这个域名是一定不要带protocol的,比如说 http://www.sagosoft.com/ 这样是不对的,这是URL不是域名

  域名应该是类似 www.sagosoft.com这样的 【否则在微信js-sdk接入时会提示invalid url domain】

4)关注公众号

  用户只有关注了这个公众号了,才能通过打开有公众号信息的链接去授权第三方登录,并获取用户信息的操作。故我们还需要用我们的微信关注微信号,操作如下:

  还是刚刚那个登录成功后跳转的页面,我们可以看到,该页面有一个二维码,我们可以通过扫描该二维码进行关注,关注成功在右边的“用户列表”会多一个用户的信息。如下图所示:

5)配置回调函数

我们在微信客户端访问第三方网页(即我们自己的网页)的时候,我们可以通过微信网页授权机制,我们不仅要有前面获取到的appid和appsecret还需要有当用户授权之后,回调的域名设置,即用户授权后,页面会跳转到哪里。具体的配置如下:

还是在刚刚的页面,有一个“网页授权获取用户基本信息”,点击后面的修改

填写回调的域名:

域名是上面配置的根域名,假如你上面 “接口配置信息” 填写的url 为zcr.sinaaappc.com/wx_sample.php,这里只要填写zcr.sinaaappc.com 就可以了。

如果你的网址没有被列入过黑名单,就会在顶部出现

注意:

1、这里填写的是域名(是一个字符串),而不是URL,因此请勿加http://等协议头;

2、授权回调域名配置规范为全域名,比如需要网页授权的域名为:www.qq.com,配置以后此域名下面的页面http://www.qq.com/music.html 、 http://www.qq.com/login.html 都可以进行OAuth2.0鉴权。但http://pay.qq.com 、 http://music.qq.com 、 http://qq.com无法进行OAuth2.0鉴权

到这里,我们就完成了公众号测试账号的获取和配置,已经用户关注微信公众号。

4、通过appid和appsecret获取我们的access_token

  access_token是公众号的全局唯一票据,公众号调用各接口时都需使用access_token。开发者需要进行妥善保存。access_token的存储至少要保留512个字符空间。access_token的有效期目前为2个小时,需定时刷新,重复获取将导致上次获取的access_token失效。

获取方法:

http请求方式: GET

https://api.weixin.qq.com/cgi-bin/token?grant_type=client_credential&appid=APPID&secret=APPSECRET

参数说明:

返回说明

正常情况下,微信会返回下述JSON数据包给公众号:

 

复制代码代码如下:
{"access_token":"ACCESS_TOKEN","expires_in":7200}

 

错误时微信会返回错误码等信息,JSON数据包示例如下(该示例为AppID无效错误):

 

复制代码代码如下:
{"errcode":40013,"errmsg":"invalid appid"}

 

例子:

获取access_token:

 

复制代码代码如下:
https://api.weixin.qq.com/cgi-bin/token?grant_type=client_credential&appid=wx4d1cb8dbd827a16e9&secret=d462d4c36b116795d1d99dcf0547af5443d

 

返回数据:

1
2
3
4
{
"access_token"
:
"qR5UK2vMf5aTHV8e-uB10FZW0caTZm_1kbkUe4OPK2ILVvNaoa7pLzYWqLUAmx6Sjq1E7pKHrVAtuG0_1MPkqmDfOkm2750kaLWNk59DS-iDOpjjxompJtXa3WhbN5FKRWNhADAVAR"
,
"expires_in"
: 7200
}

5、通过access_token群发短信

  在公众平台网站上,为订阅号提供了每天一条的群发权限,为服务号提供每月(自然月)4条的群发权限。而对于某些具备开发能力的公众号运营者,可以通过高级群发接口,实现更灵活的群发能力。

请注意:

1、对于认证订阅号,群发接口每天可成功调用1次,此次群发可选择发送给全部用户或某个分组;

2、对于认证服务号虽然开发者使用高级群发接口的每日调用限制为100次,但是用户每月只能接收4条,无论在公众平台网站上,还是使用接口群发,用户每月只能接收4条群发消息,多于4条的群发将对该用户发送失败;
3、具备微信支付权限的公众号,在使用群发接口上传、群发图文消息类型时,可使用<a>标签加入外链;
4、开发者可以使用预览接口校对消息样式和排版,通过预览接口可发送编辑好的消息给指定用户校验效果。

1)根据分组进行群发【订阅号与服务号认证后均可用】

调用接口:

 

复制代码代码如下:
http请求方式: POSThttps://api.weixin.qq.com/cgi-bin/message/mass/sendall?access_token=ACCESS_TOKEN

 

在body添加如下数据(以JSON格式数据发送)——发送其他格式数据,只需要改里面参数信息即可,具体可查看:

1
2
3
4
5
6
7
8
9
10
{
"filter"
:{
"is_to_all"
:false,
"group_id"
:2
},
"text"
:{
"content"
:
"CONTENT"
},
"msgtype"
:
"text"
}

参数说明:

例子:发送给所有人

url:

 

复制代码代码如下:
https://api.weixin.qq.com/cgi-bin/message/mass/sendall?access_token=KBoNONaJZ4-KhafQVJoQ6VBX0F-bls7nAsJBn8Fy7GLwav4Be1lRJcob1RHH6wW35IxxFwkJnZfnc-On9EQITg3oxEWUw7O2YyVW9naDknu6PQX9fnSmQcr8ojTK8Ug-HDTcAAABXN

 

发送的json数据:发送给所有人

1
2
3
4
5
6
7
8
9
{
"filter"
:{
"is_to_all"
:true
},
"text"
:{
"content"
:
"CONTENT"
},
"msgtype"
:
"text"
}

返回数据:

1
2
3
4
5
{
"errcode"
: 0,
"errmsg"
:
"send job submission success"
,
"msg_id"
: 1000000003
}

参数意义:

错误码及其以及查询:

使用postman模拟https请求发送如下图所示:

2)根据OpenID列表群发【订阅号不可用,服务号认证后可用】

发送的http请求url:(注意:和上面的不同)

 

复制代码代码如下:
http请求方式: POSThttps://api.weixin.qq.com/cgi-bin/message/mass/send?access_token=ACCESS_TOKEN

 

数据格式:

 

复制代码代码如下:
{"touser":["OPENID1","OPENID2"],"msgtype": "text","text": { "content": "hello from boxer."}}

 

其中OPENID1和OPENID2是我们要发送的微信用户openId(用户的唯一标示)。

例子:

发送"oF3PcsnsrMiJzEwalZZbAfWQpxCI","oF3PcshH1CUIhR_WYau6swUiPzlw" 两个用户。

内容为:hello from boxer.<a href='www.baidu.com'>欢迎来到百度</a>

url:

 

复制代码代码如下:
https://api.weixin.qq.com/cgi-bin/message/mass/send?access_token=wRyTbnsiu18ssEhMPLf4bDfeT-Bt6e6tgR4CQGVLBipRcyJPkdAKPYfM6-qkKuHUN8uRKJh6Xvm0OuAdFgqOo8Ru8hoDxl-cGc9bh-ezJb2ZUcJSnQk2s416zI8kbEOfOGYdAFARJB

 

json数据:

1
2
3
4
5
6
7
8
{
"touser"
:[
"oF3PcsnsrMiJzEwalZZbAfWQpxCI"
,
"oF3PcshH1CUIhR_WYau6swUiPzlw"
],
"msgtype"
:
"text"
,
"text"
: {
"content"
:
"hello from boxer.<a href=''>欢迎希沃学院</a>"
}
}

返回数据:

1
2
3
4
5
{
"errcode"
: 0,
"errmsg"
:
"send job submission success"
,
"msg_id"
: 3147483654
}

使用postman模拟发送请求如下:

微信号接收到的内容:

致谢:感谢您的阅读!

转载于:https://www.cnblogs.com/yyjie/p/7305987.html

你可能感兴趣的文章
pip3换源,grep,sed ,awk 三剑客,通配符,linux运行django项目
查看>>
让 framset 框架中的页面全屏显示
查看>>
对于Spring使用注解的一点总结
查看>>
tomcat 解析(五)-Tomcat的核心组成和启动过程
查看>>
linux mysql
查看>>
UEP-find查询
查看>>
C++内存模型
查看>>
range和xrange的区别详解
查看>>
su: Authentication failure问题
查看>>
P1334 瑞瑞的木板
查看>>
RedHat AS4 U4 kernel-2.6.9-5 --> kernel-2.6.9-42 升级
查看>>
章节八、2-火狐的插件TryXPath
查看>>
DLL(OCX)文件注册与反注册方法(regsvr32用法)
查看>>
android.graphics.Paint方法setXfermode (Xfermode x...
查看>>
iOS开发之让你的应用“动”起来
查看>>
android studio怎么添加.so文件?android studio加载so文件的方法
查看>>
LeetCode - Reverse Linked List II
查看>>
SSD果然劲爆!
查看>>
排序算法总结
查看>>
如何快速理解一个全新的嵌入式操作系统(转载)
查看>>