小程序订阅消息 | 微信开放文档

步骤一:获取订阅消息模板 ID
在微信公众平台手动配置获取模板 ID:
登录 https://mp.weixin.qq.com 获取模板,如果没有合适的模板,可以申请添加新模板,审核通过后可使用。

在公告模板库找到要用的模版添加,获取到模版ID,没有合适的可以自己申请

Java 小程序的订阅消息基于mq还是kafka_小程序

步骤二:获取下发权限

详见小程序端消息订阅接口 wx.requestSubscribeMessage

需要在微信开发者工具里index.wxml、同目录下index.js写订阅消息页面

Java 小程序的订阅消息基于mq还是kafka_微信_02

Java 小程序的订阅消息基于mq还是kafka_模版_03

<button type='primary' bindtap='getTmplID'>发送订阅消息</button> 
getTmplID: function () {
     console.log('已接收消息1')
     wx.requestSubscribeMessage({
       tmplIds: ['模版ID'],
       success(res) {
         console.log(res)
         if (res['模版ID'] === 'accept') {
           console.log('用户同意了')
           wx.showToast({
             title: '订阅OK!',
             duration: 1000,
           })
           /*****服务器主动推送的话,不需要调用***************/
           wx.request({
             method: 'POST',
             url: '订阅消息接口api',
             //不是josn格式
             header: {
               'content-type': 'application/json'
             },
             data: {
             },
             //调用接口成功
             success: function (res) {
               console.log(res);
             },
           });
  
         }
       },
       fail(err) {
         //失败
         console.error(err);
         reject()
       }
     })

然后真机调试扫码。注意,只能真机调试

在手机端微信扫码打开进行测试

点击 ‘发送订阅消息’ 后,如图所示,选择允许

  

Java 小程序的订阅消息基于mq还是kafka_小程序_04

步骤三:调用接口下发订阅消息

详见服务端消息发送接口 subscribeMessage.send

thinkphp5.0框架

class Wechatsubscribe extends Base
{

    public function sendMessage()
    {
        $appid = 'bdd7adf365';
        $appsecret = '6257e434e8b3ad697f5b7';
        $touser = 'OA3N4-I56PsV-k';//用户openid
        $template_id = 'BUFcK6fWxYEkyk1ZFweGQ1SgY';//所需下发的订阅模板id
        $page = 'moduleD/pages/s_details/s_details';//跳转页面不填则模板无跳转。
        $url = 'https://api.weixin.qq.com/cgi-bin/token?grant_type=client_credential&appid=' . $appid . '&secret=' . $appsecret;

        $res = json_decode(file_get_contents($url), true);

        $access_token = $res['access_token'];

        //请求url
        $url = 'https://api.weixin.qq.com/cgi-bin/message/subscribe/send?access_token=' . $access_token;
        //发送内容
        $data = [];

        //接收者(用户)的 openid
        $data['touser'] = $touser;

        //所需下发的订阅模板id
        $data['template_id'] = $template_id;

        //点击模板卡片后的跳转页面,仅限本小程序内的页面。支持带参数,(示例index?foo=bar)。该字段不填则模板无跳转。
        $data['page'] = $page;

        //模板内容,格式形如 { "key1": { "value": any }, "key2": { "value": any } }
        $data['data'] = [
            "phrase1" => [
                'value' => '测试'
            ],
            "thing2" => [
                'value' => '公证处摇号'
            ],
            "date3" => [
                'value' => date("Y-m-d H:i:s")
            ],
            'thing4' => [
                'value' => '摇号结束'
            ],
        ];
        //跳转小程序类型:developer为开发版;trial为体验版;formal为正式版;默认为正式版
        $data['miniprogram_state'] = 'developer' ;
        return self::curlPost($url,json_encode($data)) ;
    }

    //发送post请求
    static function curlPost($url,$data)
    {
        $ch = curl_init();
        $params[CURLOPT_URL] = $url;    //请求url地址
        $params[CURLOPT_HEADER] = FALSE; //是否返回响应头信息
        $params[CURLOPT_SSL_VERIFYPEER] = false;
        $params[CURLOPT_SSL_VERIFYHOST] = false;
        $params[CURLOPT_RETURNTRANSFER] = true; //是否将结果返回
        $params[CURLOPT_POST] = true;
        $params[CURLOPT_POSTFIELDS] = $data;
        curl_setopt_array($ch, $params); //传入curl参数
        $content = curl_exec($ch); //执行
        curl_close($ch); //关闭连接
        return $content;
    }

}

 然后用Postman调接口测试

errCode返回失败错误码可参考小程序订阅消息文档进行查看

 

Java 小程序的订阅消息基于mq还是kafka_模版_05

微信收到服务通知 

 

Java 小程序的订阅消息基于mq还是kafka_小程序_06


如不喜请联系本人 即可删除