zoukankan      html  css  js  c++  java
  • php之微信公众号发送模板消息

    讲一下开发项目中微信公众号发送模板消息的实现过程(我用的还是Thinkphp5.0)。

    先看一下效果,如图:

    就是类似于这样的,下面讲一下实现过程:

    第一步:微信公众号申请模板消息权限:

    立即申请:

    申请过程就不说了,提交并且申请通过后,可以在模板库中看到模板消息列表:

    想用哪个模板点击进去添加就行了:

    添加模板后就存放到“我的模板库”中了,这是我添加的需要用到的一些:

    点击查看模板的详情,可以看到模板的id及各项内容参数名,不同的模板消息的内容结构不一样。这些id及字段名在程序中会使用到:

    第二步:程序实现模板消息SDK:

    同样的,模板消息是使用access token来发送的,所以要获取token。

    我把模板消息的类文件放在了extend下面,大致位置如图:

    代码截图如下:

    类文件这样就可以了,到时候直接引入使用就可以了。

    第三步:构建模板消息:

    我把需要用到的模板消息 都写成一个个方法,放在公共类文件中了,可以参考一下:

    //下单成功通知模板
    /*
     * openid:微信唯一标识
     * orderSn:订单号
     * goods_name:商品名称
     * goods_num:商品数量
     * allMoney:总价格
     */
    function orderSuccess($openid=null,$orderSn=null,$goods_name=null,$goods_num=null,$allMoney=null){
        $template = array(
            "touser" => "$openid",
            "template_id" => "gApc7CzZSiJOZ7OeoXKK8APmz-dcuQuwfBTzPblEWv4",
            'url' => '跳转地址',
            'topcolor' => '#ccc',
            'data' => array('first'   => array('value' =>urlencode('亲,您的订单已创建成功,我们会立即为您备货,并在第一时间内为您安排专人免费送货到家!订单详情如下'),
                                               'color' =>"#743A3A",
            ),
                'keyword1' => array('value' =>urlencode($orderSn),
                                    'color' =>'#FF0000'
                ),
                'keyword2' => array('value' =>urlencode($goods_name),
                                    'color' =>'#FF0000'
                ),
                'keyword3' => array('value' =>urlencode($goods_num),
                                    'color' =>'#FF0000'
                ),
                'keyword4' => array('value' =>urlencode($allMoney),
                                    'color' =>'#FF0000'
                ),
                'keyword5' => array('value' =>urlencode('在线支付'),
                                    'color' =>'#FF0000'
                ),
                'remark'   => array('value' =>urlencode('如果您对以上信息有任何疑问,请直接在平台上回复您的问题即可,或拨打客服电话4001021789。再次感谢您的惠顾!'),
                                    'color' =>'#FF0000'
                ),
            )
        );
        return $template;
    }

    这只是我写的其中一个下单成功的模板消息,放在common文件中了,这样基本上就完成了:

    下面引用模板消息发送到微信公众号中

    //构造消息模板
                        $template =orderSuccess($openid,$reoderSn,$goodsNames,$sum,$money);
                        //引入模板消息类
                        Loader::import('orgWxMessage', EXTEND_PATH);
                        //实例化消息类
                        $message = new WxMessage();
                        //发送消息
                        $message->send_template_message(urldecode(json_encode($template)));
    

      

    用loader引入extend下的消息类文件,发送消息后,就得到了刚开始的那张图片内容。

    挺简单的,感觉有用的可以参考一下试试看。

    本文属原创内容,为了尊重他人劳动,转载请注明本文地址:

    http://www.cnblogs.com/luokakale/p/8143684.html

  • 相关阅读:
    angular 组件间数据共享
    Linux 常用命令
    angular 子路由跳转出现Navigation triggered outside Angular zone, did you forget to call ‘ngZone.run() 的问题修复
    angular :ngIf 的else用法
    利用 filter 来去重
    webpack打包时删除console.log,和debugger
    git忽略而不提交文件的3种情形
    jenkins 构建日程表配置
    vue之多页面的开发
    vue-cli3使用jq
  • 原文地址:https://www.cnblogs.com/yszr/p/10737575.html
Copyright © 2011-2022 走看看