jiguang/jsms

v1.0.9 2019-04-25 09:13 UTC

This package is not auto-updated.

Last update: 2024-09-20 10:37:51 UTC


README

这是一个短信API的PHP版本封装开发包,由极光官方提供,通常支持最新的API功能。

对应的API文档:https://docs.jiguang.cn/jsms/server/rest_api_summary/

支持的PHP版本:5.3.3 ~ 5.6.x, 7.0.x 需要启用cURL扩展

安装

  • 在项目中的 composer.json 文件中添加 JSMS 依赖:
"require": {
    "jiguang/jsms": "~1.0"
}
  • 执行 $ php composer.phar install$ composer install 进行安装。

使用

初始化

use JiGuang\JSMS as JSMS;
...
...

    $client = new JSMS($app_key, $master_secret);

...

或者

$client = new \JiGuang\JSMS($app_key, $master_secret);

证书问题

// 禁用 SSL 证书的验证,
$client = new JSMS($app_key, $master_secret, [ 'disable_ssl' => true ]);

希望开发者在了解相关风险的前提下如此处理SSL证书问题。

发送验证码

$client->sendCode($phone, $temp_id, $sign = null);

参数说明

$phone: 接收验证码的手机号码

$temp_id: 模板ID

$sign_id: 签名ID,null 表示使用应用默认签名

发送语音短信验证码

$client->sendVoiceCode($phone, $options = []);

参数说明

$phone: 接收验证码的手机号码

$options: 可选选项数组,接受 3 个键 ttlcodevoice_lang 中的一个或多个。

  • ttl: 超时时间,默认为 60 秒
  • code: 语音验证码的值,验证码仅支持 4-8 个数字
  • voice_lang: 播报语言选择,0:中文播报,1:英文播报,2:中英混合播报

验证

$client->checkCode($msg_id, $code);

参数说明

$msg_id: 发送验证码 sendCode 函数返回的数组中的 msg_id 键对应的值

$code: 手机接收到的验证码

发送模板短信

$client->sendMessage($mobile, $temp_id, array $temp_para = [], $time = null, $sign_id = null);

参数说明

$phone: 接收验证码的手机号码

$temp_id: 模板 ID

$temp_para: 模板参数,需要替换的参数名和 value 的键值对,仅接受数组类型的值

$time: 定时短信发送时间,格式为 yyyy-MM-dd HH:mm:ss,默认为 null 表示立即发送

$sign_id: 签名ID,null 表示使用应用默认签名

发送批量模板短信

$client->sendBatchMessage($temp_id, array $recipients,$time = null, sign_id = null, $tag = null);

参数说明

$temp_id: 模板 ID

$recipients: 接收者列表,接受一个以 mobile 为键,对应其 temp_para 为值的关联数组

$time: 定时短信发送时间,格式为 yyyy-MM-dd HH:mm:ss,默认为 null 表示立即发送

$sign_id: 签名ID,null 表示使用应用默认签名

$tag: 标签,仅用作标示该短信的别名,不在短信中展示,最多不超过 10 个字

查询定时模板短信

$client->showSchedule($scheduleId);

删除定时模板短信

$client->deleteSchedule($scheduleId);

应用余量查询

$client->getAppBalance();

调用返回码说明

http://docs.jiguang.cn/server/rest_api_jsms/#_12

示例

下载中的 examples 文件夹中有简单示例代码,开发者可以参考其中的样例快速了解该库的使用方法。

注:所下载的样例代码不可马上使用,需要在相应文件中填入相关的必要参数,不然示例运行会失败

简单使用方法

假定当前目录为 JSMS 源码所在的根目录

  • 编辑 examples/config.php 文件,填写信息
$appKey = 'xxxx';
$masterSecret = 'xxxx';
$phone = 'xxxxxxxxxxx';
  • 运行示例 $ php examples/send_example.php

  • 获取 msg_idcode

  • 编辑 examples/check_example.php 文件,填写信息

$msg_id = 'xxxx';
$code = 'xxxxxx';
  • 运行示例 $ php examples/check_example.php

贡献

欢迎在GitHub上提交bug报告和pull requests:https://github.com/jpush/jsms-api-php-client.

许可证

该库在MIT许可证下作为开源软件提供。