微信与小程序结合推送模板消息
-
描述:
因小程序是被动触发推送消息,所以要做成推送到该用户的微信公众号上
代码推送模板消息则是通过用户的openId来进行推送,但是小程序和微信公众号的openId不同,所以只能另找办法。
在微信的官网上查询到,绑定在同一个微信开放者平台上,则会生成一个unionId,这个unionId在小程序端和在微信公众号端都是一样的,所以我们拿这个来实现向微信公众号推送模板消息的功能。
-
前期准备:
微信公众号:AppId和APPSecret(必须认证)
微信小程序:AppId和APPSecret(必须认证)
微信开放者平台(小程序和公众号必须绑定同一个开放者平台,必须认证)
认证方法找微信文档或度娘即可
-
获取微信公众号的所有用户信息
- 通过微信公众号的AppId和AppSecret(当前ip地址必须在微信公众号的白名单内)
获取微信公众号的access_token(7200秒有效)
地址:https://api.weixin.qq.com/cgi-bin/token?grant_type=client_credential&appid=APPID&secret=APPSECRET
返回结果:
{
"access_token": "ACCESS_TOKEN",
"expires_in": 7200
}
(其中的APPID和APPSECRET换成自己微信公众号的appId和APPSecret)
- 通过刚才获取到的access_token去获取所有用户的openId
地址:https://api.weixin.qq.com/cgi-bin/user/get?access_token=ACCESS_TOKEN&next_openid=NEXT_OPENID
返回结果:
{
"count": 2,
"data": {
"openid": [
"OPENID1",
"OPENID2"
]
},
"next_openid": "NEXT_OPENID",
"total": 2
}
(NEXT_OPENID为超出10000个取10001继续请求,这个会在每次请求后返回的json字符串中有)
- 将所有的openId全部放在一个新的数组中,然后
for
循环,循环次数为openId的数组的长度,循环请求每个用户的基本信息
地址:https://api.weixin.qq.com/cgi-bin/user/info?access_token=ACCESS_TOKEN&openid=OPENID&lang=zh_CN
返回结果:
{
"subscribe": 1,
"openid": "o6_bmjrPTlm6_2sgVt7hMZOPfL2M",
"nickname": "Band",
"sex": 1,
"language": "zh_CN",
"city": "广州",
"province": "广东",
"country": "中国",
"headimgurl": "http://thirdwx.qlogo.cn/mmopen/g3MonUZtNHkdmzicIlibx6iaFqAc56vxLSUfpb6n5WKSYVY0ChQKkiaJSgQ1dZuTOgvLLrhJbERQQ4eMsv84eavHiaiceqxibJxCfHe/0",
"subscribe_time": 1382694957,
"unionid": " o6_bmasdasdsad6_2sgVt7hMZOPfL",
"remark": "",
"groupid": 0,
"tagid_list": [
128,
2
],
"subscribe_scene": "ADD_SCENE_QR_CODE",
"qr_scene": 98765,
"qr_scene_str": ""
}
(其中的unionid绑定了开放者平台才会有的)
- 将所有的用户信息存储在自己的数据库中
-
获取小程序用户信息
- 小程序端通过调用wx.login()会获取到一个用户登录凭证code(有效期五分钟)
- 将code传给后台,后台通过appId、APPSecret和code能够获取到这个用户的微信基本信息
地址:https://api.weixin.qq.com/sns/jscode2session?appid=APPID&secret=SECRET&js_code=JSCODE&grant_type=authorization_code
返回结果:
{
"sex": 1,
"photoUrl": "https://wx.qlogo.cn/mmopen/vi_32/DYAIOgq83eofr4W1SptUJ9M1PUiaqA4XBZiapCN98sPYOjNDXZSrUp1JcicibeLiaHZ56qlQnibQEUSFGLnEatu1TyiaA/132",
"openId": "oDl465JGG54ezszjG3K2spJV1TNM",
"uniodId": "otjNb03MD_IipC8XRdL68GOKLVgs"
}
(其中的unionid绑定了开放者平台才会有的,如果绑定后还是没有unionId,则这个小程序用户没有关注相同主体的公众号)
- 将用户信息保存在自己的数据里
-
微信公众号推送
- 本地数据库中存放着小程序用户表和微信公众号的表,下面就是向某一个小程序用户推送微信公众号信息
- 在小程序用户表中任意取一个用户A信息,用户A的openId和unionId,通过unionId到公众号表里去检索对应的A用户微信公众号的openId
- 在微信公众号上选择一个模板消息,编辑完要发送的的内容后,再请求发送模板消息的接口
地址:https://api.weixin.qq.com/cgi-bin/message/template/send?access_token=ACCESS_TOKEN
请求参数:
{
"touser": "OPENID",
"template_id": "ngqIpbwh8bUfcSsECmogfXcV14J0tQlEpBO27izEYtY",
"url": "http://weixin.qq.com/download",
"miniprogram": {
"appid": "xiaochengxuappid12345",
"pagepath": "index?foo=bar"
},
"data": {
"first": {
"value": "恭喜你购买成功!",
"color": "#173177"
},
"keyword1": {
"value": "巧克力",
"color": "#173177"
},
"keyword2": {
"value": "39.8元",
"color": "#173177"
},
"keyword3": {
"value": "2014年9月22日",
"color": "#173177"
},
"remark": {
"value": "欢迎再次购买!",
"color": "#173177"
}
}
}
参数 | 是否必填 | 说明 |
---|---|---|
touser | 是 | 接收者openid |
template_id | 是 | 模板ID |
url | 否 | 模板跳转链接 |
miniprogram | 否 | 跳小程序所需数据,不需跳小程序可不用传该数据 |
appid | 是 | 所需跳转到的小程序appid(该小程序appid必须与发模板消息的公众号是绑定关联关系,暂不支持小游戏) |
pagepath | 否 | 所需跳转到小程序的具体页面路径,支持带参数,(示例index?foo=bar),暂不支持小游戏 |
data | 是 | 模板数据 |
color | 否 | 模板内容字体颜色,不填默认为黑色 |
以上,为向微信小程序推送微信公众号的模板消息步骤。
*注:关于微信公众号不能推送的,或者推送报错的,推送的miniprogram下的appid对应的小程序必须是已审核并发布的才可以推送(这个也是我遇到的一个坑。。。。。。)