amsiam/send-sms
最新稳定版本:v1.0.0
Composer 安装命令:
composer require amsiam/send-sms
包简介
Send SMS through any bulk provider just using single package.
README 文档
README
Overview
The Amsiam\SendSMS package provides a simple and flexible way to send SMS messages in Laravel applications. It supports multiple SMS drivers and allows sending single messages, one message to multiple recipients, or multiple messages to multiple recipients. Additionally, it provides functionality to check the SMS balance for the configured driver.
Table of Contents
Requirements
- PHP: 7.4 or higher
- Laravel: 8.x or higher
- Composer: For package installation
- A valid account with a supported SMS provider (e.g., BulkSMSBD)
Installation
-
Install the package via Composer:
composer require amsiam/send-sms
-
Publish the configuration file (optional):
php artisan vendor:publish --provider="Amsiam\SendSMS\SendSMSServiceProvider"This will create a
config/sendsms.phpfile in your Laravel project. -
Register the Facade(optional): Add the
SendSMSfacade to yourconfig/app.phpfile under thealiasesarray:'aliases' => [ // Other aliases... 'SendSMS' => Amsiam\SendSMS\Facades\SendSMS::class, ],
Configuration
The package uses a configuration file (config/sendsms.php) to set the default SMS driver and driver-specific settings. Below is an example configuration:
<?php return [ 'default' => env('SMS_DRIVER', 'bulk_sms'), 'drivers' => [ 'bulk_sms' => [ 'api_key' => env('SMS_BULK_SMS_BD_API_KEY'), 'sender_id' => env('SMS_BULK_SMS_BD_SENDERID'), ], // Add other drivers here ], ];
Environment Variables
Add the following to your .env file to configure the driver:
SMS_DRIVER=bulk_sms SMS_BULK_SMS_BD_API_KEY=your_api_key SMS_BULK_SMS_BD_SENDERID=your_sender_id
Available Configuration Options
default: The default SMS driver (e.g.,bulk_sms).drivers: An array of driver-specific configurations, such as API keys and base URLs.
Usage
The SendSMS class provides methods to send SMS messages and check balances. You can use it via the Amsiam\SendSMS\Facades\SendSMS facade, which simplifies imports and usage.
Setting a Driver
By default, the package uses the driver specified in the default configuration. To switch drivers programmatically:
use Amsiam\SendSMS\Enums\SMSDriver; use Amsiam\SendSMS\Facades\SendSMS; SendSMS::setDriver(SMSDriver::BULK_SMS);
Sending a Single SMS
Send an SMS to a single phone number:
use Amsiam\SendSMS\Facades\SendSMS; $response = SendSMS::sendSMS('8801234567890', 'Hello, this is a test message!');
Sending One Message to Multiple Recipients
Send the same message to multiple phone numbers:
use Amsiam\SendSMS\Facades\SendSMS; $phones = ['8801234567890', '8809876543210']; $response = SendSMS::sendOneMessageToMany($phones, 'Hello, this is a broadcast message!');
Sending Multiple Messages to Multiple Recipients
Send different messages to different phone numbers:
use Amsiam\SendSMS\Facades\SendSMS; $phones = ['8801234567890', '8809876543210']; $messages = ['Hello John!', 'Hello Jane!']; $response = SendSMS::sendManyMessageToMany($phones, $messages);
Checking SMS Balance
Retrieve the balance for the configured SMS driver:
use Amsiam\SendSMS\Facades\SendSMS; $balance = SendSMS::getBalance();
Static Method Calls
The SendSMS facade supports static method calls, making it convenient to use without manual instantiation:
use Amsiam\SendSMS\Facades\SendSMS; $response = SendSMS::sendSMS('8801234567890', 'Hello, this is a test message!'); $balance = SendSMS::getBalance();
Note: The facade internally handles instantiation and uses the default driver.
Supported Drivers
The package currently supports the following driver:
- BulkSMSBD: A driver for the BulkSMSBD service (
Amsiam\SendSMS\Drivers\BulkSMSBDDriver).
To add support for additional drivers, implement the ISendSMSDriver interface and register the driver in the configuration.
Error Handling
- If the driver is not set or improperly configured, methods like
sendSMS,sendOneMessageToMany,sendManyMessageToMany, andgetBalancewill returnnull. - Static calls to undefined methods will throw a
BadMethodCallException. - Ensure the phone numbers and messages are valid for the driver being used (e.g., correct format for BulkSMSBD).
Example of handling errors:
use Amsiam\SendSMS\Facades\SendSMS; try { $response = SendSMS::sendSMS('8801234567890', 'Test message'); if ($response === null) { // Handle driver not set or failed request echo "Failed to send SMS."; } else { // Handle success echo "SMS sent successfully!"; } } catch (\Exception $e) { // Handle exceptions (e.g., network issues, invalid configuration) echo "Error: " . $e->getMessage(); }
Support
For issues or feature requests, please contact the package maintainer or open an issue on the package's GitHub repository (if available). Ensure you provide:
- Laravel version
- PHP version
- Package version
- Relevant error messages or logs
For driver-specific issues (e.g., BulkSMSBD), contact the SMS provider's support team.
统计信息
- 总下载量: 1
- 月度下载量: 0
- 日度下载量: 0
- 收藏数: 0
- 点击次数: 0
- 依赖项目数: 0
- 推荐数: 0
其他信息
- 授权协议: MIT
- 更新时间: 2025-04-28