# 阿里大于 短信API接口 TP5专用类库
>[warning] 独立类库 无需安装阿里的SDK
>[info] 使用方法
* 方法一 使用默认设置
~~~
function index(){
return SendSms::instance()->send("13925262623","123541");
}
~~~
* 方法二 使用制定设置
~~~
function index(){
return SendSms::instance("mikkle2")->send("13925262623","123541");
}
~~~
* 方法三 使用自定义设置
~~~
function index(){
$options=[
[
'AccessKeyId' => '********', // 访问密钥,在阿里云的密钥管理页面创建
'AccessSecret' => '************', // 访问密钥,在阿里云的密钥管理页面创建
'TemplateCode' => 'SMS_******', // 短信模板ID
'SignName'=>'管理平台',
],
];
return SendSms::instance($options)->send("13925262623","123456");
}
~~~
>[danger] 配置文件
>extra/alisms.php
~~~
<?php
/**
* Created by PhpStorm.
* User: Mikkle
* QQ:776329498
* Date: 2017/12/11
* Time: 11:53
*/
return [
"default_options_name"=>"mikkle",
"mikkle" =>[
'AccessKeyId' => '********', // 访问密钥,在阿里云的密钥管理页面创建
'AccessSecret' => '************', // 访问密钥,在阿里云的密钥管理页面创建
'TemplateCode' => 'SMS_******', // 短信模板ID
'SignName'=>'管理平台',
],
"mikkle2" =>[
'AccessKeyId' => '********', // 访问密钥,在阿里云的密钥管理页面创建
'AccessSecret' => '************', // 访问密钥,在阿里云的密钥管理页面创建
'TemplateCode' => 'SMS_******', // 短信模板ID
'SignName'=>'管理平台',
],
];
~~~
>[danger] 类库文件
> mikkle\tp_aliyun
~~~
<?php
/**
* Created by PhpStorm.
* User: Mikkle
* QQ:776329498
* Date: 2017/12/11
* Time: 11:58
*/
namespace mikkle\tp_aliyun;
use mikkle\tp_master\Exception;
use mikkle\tp_master\Config;
use mikkle\tp_master\Log;
use mikkle\tp_master\Validate;
use mikkle\tp_tools\ShowCode;
class SendSms
{
static protected $instance;
protected $accessKeyId;
protected $accessSecret;
protected $templateCode;
protected $signName;
protected $requestHost = "http://dysmsapi.aliyuncs.com";
protected $requestUrl;
protected $signature;
protected $requestParas;
protected $error;
public function __construct($options=[])
{
ini_set('date.timezone','Asia/Shanghai');
date_default_timezone_set("GMT");
isset($options["AccessKeyId"]) && $this->accessKeyId = $options["AccessKeyId"];
isset($options["AccessSecret"]) && $this->accessSecret = $options["AccessSecret"];
isset($options["TemplateCode"]) && $this->templateCode = $options["TemplateCode"];
isset($options["SignName"]) && $this->signName = $options["SignName"];
}
static public function instance($options=[]){
$options =self::getOptions($options);
$sn = self::getSn($options);
if(isset(self::$instance[$sn])){
return self::$instance[$sn];
}else{
return self::$instance[$sn]= new static($options);
}
}
/**
* @title setAccessKeyId
* @description 设置AccessKey
* @author Mikkle
* @param string $accessKeyId
* @return $this
*/
public function setAccessKeyId($accessKeyId=""){
if (!empty($accessKeyId) && is_string($accessKeyId) ){
$this->accessKeyId = $accessKeyId;
}
return $this;
}
/**
* @title setAppSecret
* @description
* @author Mikkle
* @param string $accessSecret
* @return $this
*/
public function setAppSecret($accessSecret=""){
if (!empty($accessSecret) && is_string($accessSecret) ){
$this->accessSecret = $accessSecret;
}
return $this;
}
public function setTemplateCode($templateCode=""){
if (!empty($templateCode) && is_string($templateCode) ){
$this->templateCode = $templateCode;
}
return $this;
}
public function setSignName($signName=""){
if (!empty($signName) && is_string($signName) ){
$this->signName = $signName;
}
return $this;
}
/**
* @title send
* @description 发送
* @author Mikkle
* @param string $phone
* @param string $code
* @return array|mixed
*/
public function send($phone="",$code=""){
try{
if (!$this->checkParams($phone , $code )) {
throw new Exception($this->error);
}
if ($this->createRequestUrl( $phone , $code )&&$this->signature) {
$url="{$this->requestHost}/?Signature={$this->signature}{$this->requestUrl}";
$content = $this->fetchContent($url);
return json_decode($content);
}else{
throw new Exception("参数缺失");
}
}catch (Exception $e){
Log::error($e->getMessage());
return ShowCode::codeWithoutData(1008,$e->getMessage());
}
}
protected function createRequestUrl($phone = "", $code = "")
{
try {
$requestParams = [
'RegionId' => 'cn-hangzhou', // API支持的RegionID,如短信API的值为:cn-hangzhou
'AccessKeyId' => $this->accessKeyId, // 访问密钥,在阿里云的密钥管理页面创建
"Format" => 'JSON', // 返回值类型,没传默认为JSON,可选填值:XML
"SignatureMethod" => 'HMAC-SHA1', // 编码(固定值不用改)
"SignatureVersion" => '1.0', // 版本(固定值不用改)
'SignatureNonce' => uniqid(mt_rand(0, 0xffff), true), // 用于请求的防重放攻击的唯一加密盐
'Timestamp' => date('Y-m-d\TH:i:s\Z'), // 格式为:yyyy-MM-dd’T’HH:mm:ss’Z’;时区为:GMT
'Action' => 'SendSms', // API的命名,固定值,如发送短信API的值为:SendSms
'Version' => '2017-05-25', // API的版本,固定值,如短信API的值为:2017-05-25
'PhoneNumbers' => $phone, // 短信接收号码
'SignName' => $this->signName, // 短信签名
'TemplateCode' => $this->templateCode, // 短信模板ID
'TemplateParam' => json_encode([ // 短信模板变量替换JSON串
"code" => $code,
]),
];
ksort($requestParams);
$requestUrl = "";
foreach ($requestParams as $key => $value) {
$requestUrl .= "&" . $this->encode($key) . "=" . $this->encode($value);
}
$this->requestUrl = $requestUrl ;
$stringToSign = "GET&%2F&" . $this->encode(substr($requestUrl, 1));
// 清除最后一个&
$this->signature = base64_encode(hash_hmac('sha1', $stringToSign, $this->accessSecret . '&', true));
$this->requestParas["Signature"]=$this->signature ;
if (empty($this->signature)){
throw new Exception("URL加密错误");
}
return true;
} catch (Exception $e) {
Log::error($e->getMessage());
$this->error = $e->getMessage();
return false;
}
}
protected function checkParams($phone="",$code=""){
if (empty($this->accessKeyId) || empty($this->accessSecret) ||empty($this->templateCode) ){
$this->error = "获取短息发送接口参数缺失";
return false;
}
$validate = new Validate([
['phone','require|regex:/1[34578]{1}\d{9}$/','手机号不能为空|手机号错误'],
['code','require','验证码不存在'],
]);
$data=[
"phone"=>$phone,
"code"=>$code,
];
if (!$validate->check($data)) {
$this->error = $validate->getError();
return false;
}
return true;
}
protected function encode($url)
{
$url = urlencode($url);
$url = preg_replace('/\+/', '%20', $url);
$url = preg_replace('/\*/', '%2A', $url);
$url = preg_replace('/%7E/', '~', $url);
return $url;
}
static protected function getOptions($options=[]){
if (empty($options)&& !empty( Config::get("alisms.default_options_name"))){
$name = "alisms".".".Config::get("alisms.default_options_name");
$options = Config::get("$name");
}elseif(is_string($options)&&!empty( Config::get("alisms.$options"))){
$options = Config::get("alisms.$options");
}
if (empty($options)) {
$error[]="获取短息发送接口参数缺失";
throw new Exception("获取短息发送接口参数缺失");
}elseif(isset($options["AccessKeyId"])&&isset($options["AccessSecret"])){
return $options ;
}else{
throw new Exception("短息发送接口参数不完整");
}
}
static protected function getSn($options=[]){
$options =self::getOptions($options);
return md5("{$options["AccessKeyId"]}{$options["AccessSecret"]}");
}
private function fetchContent($url) {
if(function_exists("curl_init")) {
$ch = curl_init();
curl_setopt($ch, CURLOPT_URL, $url);
curl_setopt($ch, CURLOPT_TIMEOUT, 5);
curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);
curl_setopt($ch, CURLOPT_HTTPHEADER, array(
"x-sdk-client" => "php/2.0.0"
));
$rtn = curl_exec($ch);
if($rtn === false) {
trigger_error("[CURL_" . curl_errno($ch) . "]: " . curl_error($ch), E_USER_ERROR);
}
curl_close($ch);
return $rtn;
}
$context = stream_context_create(array(
"http" => array(
"method" => "GET",
"header" => array("x-sdk-client: php/2.0.0"),
)
));
return file_get_contents($url, false, $context);
}
}
~~~
- 序言及更新日志
- 前言一 开发PHP必备的环境(你可以不看)
- LinUX系统ThinkPHP5链接MsSQL数据库的pdo_dblib扩展
- centos7.2挂载硬盘攻略
- Centos系统Redis安装及Redis的PHP扩展安装
- Centos系统增加Swap(系统交换区)的方法
- 前言二 开发PHP软件配置和介绍(你依然可以不看)
- 数据库SQL文件
- 本地Git(版本控制)的搭建
- GIT远程仓库的克隆和推送
- Git常用命令
- PHP面向对象思想实战经验领悟
- PHP面向对象实战----命名空间
- PHP面向对象实战----继承
- 基类实战--底层方法封装
- 基类实战--构造函数实战
- 基类实战--析构函数的使用
- TP5实战开发前篇---控制器(controller)
- 控制器中Request类的使用
- 控制器中基类的使用
- TP5实战开发前篇---模型篇(model)
- TP5实战开发前篇---验证器篇(Validate)
- TP5实战课程入门篇---花拳绣腿
- 模块以及类的文件的建立
- Api开发------单条信息显示
- Api开发---单条信息复杂关联显示
- Api开发---查询信息缓存Cache的应用
- TP5实战技巧---开发思路 引路造桥
- TP5实战技巧---整合基类 化繁为简
- TP5实战课程入门篇---数据操作
- Api开发---数据的添加和修改
- API开发---快速开发API通用接口
- TP5专用微信sdk使用教程
- THINKPHP5微信SDK更新记录及升级指导
- TP5专用SDK 微信参数配置方法
- 微信公众号推送接口对接教程
- 微信推送接口对接示例含扫描登录微信端部分
- TP5专用微信支付SDK使用简介
- TP5专用支付宝支付SDK使用说明
- 使用NW将开发的网站打包成桌面应用
- TP5高阶实战课程 进阶篇概述
- 进阶篇一 实战开发之习惯及要求
- 进阶篇二 实战开发之控制器
- 控制器基类之控制器基类使用方法
- 控制器基类之控制器基类常用方法分享
- 控制器基类之构造函数的使用方法
- 进阶篇三 实战开发之权限控制
- TP5实战源码 --- 全局用户信息验证类Auth
- TP5实战源码 --- 微信Auth实战开发源码
- 进阶篇四 实战开发之模型
- 模型基类之模型基类的用途
- 模型基类之常用数据处理方法
- 模型逻辑层之实战代码(含事务)
- 模型实战开发之模型常用方法
- 模型实战源码 --- 乐观锁的应用
- 模型实战技巧---Model事件功能的使用
- 模型事件实战应用---数据库操作日志
- 进阶篇五 实战开发之缓存(Cache)
- TP5实战源码---应用缓存获取城市信息
- TP5实战源码---应用缓存获取分类详情
- 进阶篇六 TP5类库的封装和使用
- DataEdit快捷操作类库
- ShowCode快捷使用类库
- 阿里大于 短信API接口 TP5专用类库
- DatabaseUpgrade数据库对比及更新类库
- AuthWeb权限类使用说明
- 进阶篇七 服务层的应用
- 服务层源码示例
- 服务层基类源码
- 进阶篇八 应用层Redis数据处理基类
- Redis服务层基类源码
- 进阶篇九 使用Redis类库处理一般的抢购(秒杀)活动示例
- 进阶篇十 某大型项目应用本Redis类源码示例(含事务 乐观锁)
- 进阶篇十一 逻辑层的应用
- 逻辑层基类源码
- 进阶篇 服务层代码示例
- 高阶实战课程 进阶篇持续新增中
- 高阶篇一 TP5命令行之守护任务源码
- TP5实战源码 --- 命令行
- TP5实战源码 --- 通过shell建立PHP守护程序
- 高阶篇二 使用Redis队列发送微信模版消息
- 高阶篇二 之 Worker队列基类源码
- 高阶篇三 TP5实战之Redis缓存应用
- Redis实战源码之Hash专用类库源码
- Redis实战源码之Model类结合
- Redis实战源码之模型Hash基类源码
- Redis实战源码之Hash查询使用技巧
- Redis实战源码之 shell脚本中redis赋值和取值
- 高阶篇四 Swoole的实战应用
- swoole基类代码
- Swoole扩展WebsocketServer专用类
- 基于Swoole的多Room聊天室的程序
- Swoole守护服务shell源码
- 高阶篇五 命令行异步多进程队列类的应用
- tp_worker类源码
- WorkerBase
- WorkerCommand
- WorkerRedis
- Redis类
- CycleWorkBase
- WorkerHookBase异步钩子
- 队列日志SQL
- 高阶篇六 定时执行队列类库以及使用方法
- 定时队列类库源码
- 高阶篇七 异步执行循环队列类库以及使用教程
- CycleWorkBase源码
- 高阶实战课程 进阶篇持续新增中
- Extend便捷类库源码库
- 阿里相关类库
- SendSms--验证码API接口文件
- 权限相关类库目录
- AuthWeb 权限验证类库
- Redis便捷操作类库(20171224更新)
- Redis
- Tools工具类库集
- Curl类库
- DataEdit
- Rand类库
- ShowCode类库
- Upload类库
- 附件集合
- 附件一:微信支付 实战开发源码
- 微信支付类库源代码
- Common_util_pub.php
- DownloadBill_pub.php
- JsApi_pub.php
- NativeCall_pub.php
- NativeLink_pub.php
- OrderQuery_pub.php
- Refund_pub.php
- RefundQuery_pub.php
- SDKRuntimeException.php
- ShortUrl_pub.php
- UnifiedOrder_pub.php
- Wxpay_client_pub.php
- Wxpay_server_pub.php
- WxPayConf_pub.php
- 微信支付回调页面源码
- 附件二 顺丰快递BSP接口实战开发源码
- 顺丰快递BSP接口实战开发源码
- 顺丰BSP基类
- 顺丰BSP基础代码
- 顺丰BSP下单接口
- 顺丰BSP查单接口
- 顺丰BSP确认/取消接口
- 附件三 APP注册登陆接口源码(含融云平台接口)
- 附件四 TP5订单Model(含事务 获取器 修改器等方法)
- 附录五 RSA加密解密
- Rsa文件源码
- 附件六 阿里大于短信接口
- 附件七 AES加解密类
- AES加解密类源码
- 附件八 TP5路由设置源码
- 附件九 TP5 Excel导入导出下载便捷类库
- Excel类库TP5源码
- 附件十 TP5便捷操作Redis类库源码
- TP5源码 Redis操作便捷类库
- 附件十一 TP5源码 上传文件入库类源码
- 上传类Upload源码
- Upload类上传配置文件
- 存储图像文件的数据库SQL文件
- 存储文件的数据库SQL文件
- 附件十二 TP5 图片处理增强类 支持缩略图在线显示
- 附件十三 微信推送消息接口类库源码
- 附件十三 微信推送消息接口类库源码 之 基类
- 附件十四 存储微信昵称的处理方法