首先回答一个问题:
个人申请的小程序是否可以推送?
答案是肯定的,下面记录的就是我的踏坑之旅,后台采用PHP实现。
要想完成推送大概可分为六步:
1、配置模板
2、生成小程序 AppSecret
3、获取 ACCESS_TOKEN
4、获取将要推送用户的 openID
5、提交 formId
6、推送模板信息
接下来是详细的步骤:
关于对于下文后台PHP网络请求调用的Http方法不明白的地方,或者不知道怎么用PHP发起网络请求的,可以查看我的另一篇文章
【PHP 发送网络请求】
https://www.jianshu.com/p/77096b4c2eff
这里我把方法粘贴过来:
function Http($url,$data,$type="http"){
$curl = curl_init();
if ($type == "json"){
$headers = array("Content-type: application/json;charset=UTF-8");
$data=json_encode($data);
curl_setopt($curl, CURLOPT_HTTPHEADER, $headers);
}
curl_setopt($curl, CURLOPT_URL, $url);
curl_setopt($curl, CURLOPT_SSL_VERIFYPEER, FALSE);
curl_setopt($curl, CURLOPT_SSL_VERIFYHOST, FALSE);
if (!empty($data)){
curl_setopt($curl, CURLOPT_POST, 1);
curl_setopt($curl, CURLOPT_POSTFIELDS,$data);
}
curl_setopt($curl, CURLOPT_RETURNTRANSFER, 1);
$output = curl_exec($curl);
curl_close($curl);
return $output;
}
我用的curl发的网络请求,你可以采用其他的方法。
1、配置模板
点击添加会到模板库里面挑选你想推送的模板
配置好点击提交,就OK了。
2、生成小程序 AppSecret
点击【生成】或者【重置】,便会让你扫码验证,验证好后就会弹出下面这个框
这里的AppSecret你需要记录下,因为他不会出现在你的管理界面,如果要找回就只有重置,一但重置之前的就会失效。
3、获取 ACCESS_TOKEN
文档地址:
https://mp.weixin.qq.com/wiki?t=resource/res_main&id=mp1421140183
支持POST、GET请求
access_token的有效期目前为2个小时,所以对于后台来说,需要定时获取。
PHP代码片段:
$data = [
"grant_type"=>"client_credential",
"appid"=>$appId,
"secret"=>$appSecret
];
$r = http_request("https://api.weixin.qq.com/cgi-bin/token",$data);
//返回的是字符串,需要用json_decode转换成数组
$data = json_decode($r,true);
4、获取将要推送用户的 openID
这一步需要小程序操作了,调用wx.login
获取js_code发送给后台,后台用js_code换取用户的openID。
代码片段:
var that = this;
//获取js_code
wx.login({
success: res => {
var code = res.code;
//把js_code发送给后台
that.loginRequest(code);
},
fail: e=> {
}
})
//网络请求
loginRequest: function(code){
wx.request({
url: "/**/login", //这个链接需要换成你项目的链接
data: {
"code":code
},
method: 'POST',
header: {
'content-type': 'application/x-www-form-urlencoded' // 如果不加这请求头,PHP可能无法获取到发送过去的数据
},
success: function (res) {
console.log(res.data)
}
})
}
后台换取openID
js_code 换取 openID接口
代码片段:
$r = http_request("https://api.weixin.qq.com/sns/jscode2session",[
"grant_type"=>"authorization_code",
"appid"=>$appId,
"secret"=>$appSecret,
"js_code"=>$code
]);
$rdata = json_decode($r,true);
5、提交 formId
获取 openID 以及开发者的 ACCESS_TOKEN 就类似于做好了微信的授权。
接下来就可以开始做推送操作了。
由于微信不允许开发者主动推送杂七杂八的消息,必须要用户自愿接受推送,如果提现自愿,就通过用户提交form表单后就代表我想接受一次。我是这样理解的,有点像微信开发里面的回复消息,用户发消息过来服务器必须在5分钟之内回复一样。
我们需要在小程序做一个表单
<form bindsubmit="formSubmit" report-submit="true">
<button formType="submit">Submit</button>
</form>
对应的js
formSubmit: function (e) {
var that = this
wx.request({
url: "/***/formid",
data: {
"form_id": e.detail.formId
},
method: 'POST',
header: {
'content-type': 'application/x-www-form-urlencoded'
},
success: function (res) {
console.log(res.data)
},
fail: function(e){
}
})
}
PHP 后台这是拿到 formID 时就可以推送了
6、推送模板信息
文档地址:
https://mp.weixin.qq.com/debug/wxadoc/dev/api/notice.html#模版消息管理
代码片段:
$data = [
"touser"=>"用户openid",
"template_id"=>"模板id",
"form_id"=>"formid",
"data"=>[
"keyword1"=>[
"value"=>"收到没",
"color"=>"#cccccc"
]
]
];
$ast = "xxx"; //ACCESS_TOKEN
$rdata = http_request("https://api.weixin.qq.com/cgi-bin/message/wxopen/template/send?access_token=".$ast, $data,"json");
$rdata = json_decode($rdata,true);
这里有个地方一定要注意:推送的地址一定要带上 access_token 参数,否者将会出现 access_token error 。
到这里PHP实现小程序推送就结束了。
最后
如果大家还有不懂或者其他问题,欢迎私信我或者评论
[获取授权]