rolikoff / iqsms-sdk
0.1.8
2020-04-12 18:30 UTC
Requires
- php: >=5.5.0
- guzzlehttp/guzzle: ~6.5
- guzzlehttp/guzzle-services: ~1.1
Suggests
- guzzlehttp/log-subscriber: ~1.0
- monolog/monolog: ~1.14
This package is not auto-updated.
Last update: 2024-09-23 13:11:25 UTC
README
分支 Fruitware/prostor-sms-php-sdk. 原始版本的问题在于随着 IQSMS API 的变化,请求的 URL 也发生了变化。作者 Fruitware/prostor-sms-php-sdk
没有接受 PR 来更新 URL,这导致了该分支的创建。
外部文档链接
安装
composer require rolikoff/iqsms-sdk
初始化
use rolikoff\iqsms\Client;
use GuzzleHttp\Client as GuzzleClient;
//set basic access authentication
$options = [
'auth' => ['username', 'password'],
];
$smsGate = new Client(new GuzzleClient($options));
启用日志记录(非必须)
所需依赖
composer require guzzlehttp/log-subscriber monolog/monolog
use GuzzleHttp\Subscriber\Log\Formatter;
use GuzzleHttp\Subscriber\Log\LogSubscriber;
use Monolog\Handler\StreamHandler;
use Monolog\Logger;
$log = new Logger('maib_guzzle_request');
$log->pushHandler(new StreamHandler(__DIR__.'/logs/prostor_sms_guzzle_request.log', Logger::DEBUG));
$subscriber = new LogSubscriber($log, Formatter::SHORT);
$smsGate->getHttpClient()->getEmitter()->attach($subscriber);
使用示例
检查余额
$balance = $smsGate->balance();
var_dump('balance', $balance);
发送短信
简单方式
use rolikoff\iqsms\Model\Sms;
use rolikoff\iqsms\Exception\BadSmsStatusException;
$sms = new Sms();
$sms->setId(unique()) // id sms в вашей системе
->setPhone('+71234567890')
->setText('тест sms');
try {
$smsGate->send($sms);
}
catch (BadSmsStatusException $ex) {
// что-то сделать с ошибкой
}
var_dump('sms', $sms);
发送多个
$sms = new Sms();
$sms->setId(unique()) // id sms в вашей системе
->setPhone('+71234567890')
->setText('тест sms')
->sender('TEST') // Подпись отправителя (например TEST);
// Название очереди статусов отправленных сообщений
$queueName = 'myQueue1';
// Дата для отложенной отправки сообщения
$scheduleTime = (new \DateTime())->modify('+1 day');
$smsCollection = $smsGate->sendQueue([$sms, $sms], $queueName, $scheduleTime);
foreach ($smsCollection as $sms) {
if ($sms->getStatus() !== $sms::STATUS_ACCEPTED) {
// что-то сделать с ошибкой
}
}