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数据包给公众号:
错误时微信会返回错误码等信息,json数据包示例如下(该示例为appid无效错误):
例子:
获取access_token:
返回数据:
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)根据分组进行群发【订阅号与服务号认证后均可用】
调用接口:
在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:
发送的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:(注意:和上面的不同)
数据格式:
其中openid1和openid2是我们要发送的微信用户openid(用户的唯一标示)。
例子:
发送"of3pcsnsrmijzewalzzbafwqpxci","of3pcshh1cuihr_wyau6swuipzlw" 两个用户。
内容为:hello from boxer.<a href='www.baidu.com'>欢迎来到百度</a>
url:
json数据:
1
2
3
4
5
6
7
8
|
{
"touser" :[
"of3pcsnsrmijzewalzzbafwqpxci" ,
"of3pcshh1cuihr_wyau6swuipzlw"
],
"msgtype" : "text" ,
}
|
返回数据:
1
2
3
4
5
|
{
"errcode" : 0,
"errmsg" : "send job submission success" ,
"msg_id" : 3147483654
}
|
使用postman模拟发送请求如下:
微信号接收到的内容:
致谢:感谢您的阅读!
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持服务器之家。