ju/msg

聚名消息管理,支持微信模板消息、短信模板、站内信,仅支持ju框架 -- By 聚名科技

v1.0.2 2021-08-03 13:25 UTC

This package is auto-updated.

Last update: 2025-03-29 00:52:24 UTC


README

1.composer引入文件

进入项目目录下执行命令 >composer require ju/msg

2.初始化数据和配置

执行代码 (new \JuMsg\Msg())->init();

【注】如果之前项目没使用过composer, 在ju.php文件

$router=new router();//加载路由

这段代码上方添加一行代码,引入composer管理(放在这里是为了不让composer里使用的函数和框架里的函数重复定义引起冲突)

//引入composer管理
require ROOT.'vendor/autoload.php';
3.配置信息

执行步骤2后,app/x目录下会生成msg.php文件,进入文件里配置相关信息

微信消息

登录微信公众平台=>基本配置=>IP白名单 配置,配置好ip才能正常发送模板消息

单公众号:需要在wx_app下配置appId和appSecret,配置后默认给这个公众号下对应的用户发送模板消息

多公众号:在发送消息时,数据里传入appId和appSecret,从而实现多公众号发送模板消息

短信

开通聚短信功能,需要在sms下配置url和access_key

单签名:需要在sms下配置qm

多签名:在发送消息时,数据里传入qm,从而实现多签名

模板设置

tpl下有参考案例,按需配置,比如某个消息类型只发送短信,只要配置sms即可

'消息类型' => [
        //站内信
        'znx' => ['lx' => 0, 'bt' => '用户{$uid}', 'nr' => '用户{$uid}已登录', 'tan' => 0],//bt=标题,nr=内容,lx=站内信类型,tan=是否弹窗提醒

        //短信
        'sms' => ['mbid' => 'SMS_20190910165056', 'xz' => 0, 'params' => ['参数1', '参数2']],//mbid=短信模板id,xz=是否限制发送频率,params=短信内容中参数列表

        //微信模板消息
        'wx'  => [
          'params'      => ['name', 'time', 'sm'],
          'touser'      => '',
          'template_id' => 'QJWjt24bdRMm-Y6k6QBkTLNtC0BYnAsjjDwwc2LUEPo',
          'url'         => '',
          'data'        => [
            'first'    => [
              'value' => '有新的客户成功提交需求,请及时处理!',
              'color' => '#173177',
            ],
            'keyword1' => [ // 申请人
                            'value' => '{$name}',
                            'color' => '#173177',
            ],
            'keyword2' => [ // 申请时间
                            'value' => '{$time}',
                            'color' => '#173177',
            ],
            'keyword3' => [ // 申请业务
                            'value' => '{$sm}',
                            'color' => '#173177',
            ],
            'remark'   => [
              'value' => '请及时登录平台查阅!',
              'color' => '#173177',
            ],
          ],
        ],
    ],
4.发送消息

4.1.直接发送

直接发送

//短信
$data = [
  'sjhm'=>'17721086033',
  'code'=>888888,
  //'qm'=>'其他签名',//可传可不传,传入后,可支持多签名
];
(new \JuMsg\Msg())->send('登录注册',0,['sms'],$data);

//站内信
$data = [
  'uid'=>'17721086033',
];
(new \JuMsg\Msg())->send('登录注册',10001,['znx'],$data);


//微信消息模板
$data = [
  'uid'=>'17721086033',
  'openid'=>'o95aL6cCD52j9CYOTdiLCAZFpO0k',
  'order_sn'=>'NO9527',
  'name'=>'纪苏',
  'sjhm'=>'17721086032',
  'ddjg'=>998,
  'zfzt'=>'支付成功',
  
/*  'appId'     => '###请替换成自己的微信公众号appId###',//登录微信公众平台=>基本配置=>appId
  'appSecret' => '###请替换成自己的微信公众号appSecret###',//登录微信公众平台=>基本配置=>appSecret
  */
  //appId和appSecret可传可不传,不传使用msg.php里的默认配置,传入后优先使用传入的数据,用以支持多公众号
];
(new \JuMsg\Msg())->send('登录注册',10001,['wx'],$data);

4.2.异步发送(先异步发送记录数据,再去队列消费数据真实发送)

异步发送 (记录数据,等待后台队列消费)

$data = [
  'sjhm'=>'17721086033',
  'code'=>888888,
  'uid'=>'17721086033',
  'openid'=>'o95aL6cCD52j9CYOTdiLCAZFpO0k',
  'order_sn'=>'NO9527',
  'name'=>'纪苏',
  'ddjg'=>998,
  'zfzt'=>'支付成功',
];
(new \JuMsg\Msg())->async_send('登录注册',10018,['sms','znx','wx'],$data);

后台消费(消费队列真实发送)

(new \JuMsg\Msg())->customer_queue();

5.常见问题

短信接入

5.1.1 需要找聚短信负责人申请账号,得到access_key和相关文档

5.1.2 签名申请需要项目上线可访问以及公司相关资料

5.1.3 需要根据业务申请不同的短信模板

微信模板消息接入

5.2.1 需要开通公众号,获取appId和appSecret,获取方式见msg.php

5.2.2 需要开通微信开放平台【会很耗时,请提前申请】,或者可让用户微信登录,从而获取用户openid

5.2.3 需要开通公众号的模板消息功能

5.2.4 需要在基本配置里设置ip白名单,不然发送会失败

5.2.5 可以使用模板库的模板,如果模板库里没有可用的模板,需要自己申请【每个月只能申请3个,审核时间比较久,也没法实时看进度,只能被动等站内信通知】