ThinkPHP 5实现发送阿里云短信功能
在日常开发的工作中,短信应用的场景非常广泛,如:验证码登录、密码修改验证、卖家发货通知、消息提醒等。本文介绍ThinkPHP 5如何对接阿里云短信,实现发送短信的功能。
一、下载阿里云短信SDK
打开下载阿里云短信PHP SDK
https://help.aliyun.com/document_detail/55359.html?spm=a2c4g.11186623.6.673.2d1b2e79dVnAb2
点击下载PHP版本的SDK
下载完成会得到一个压缩包,将压缩包解压,进入目录,目录结构如下,我们只需要api_sdk这个文件夹
二、ThinkPHP中引入短信SDK
将api_sdk这个文件夹复制到tp5的extend下面,并将api_sdk这个文件夹重命名为alisms(自己喜欢)
三、实现发送短信功能代码
引入SDK后,开始编写发送短信的具体功能代码,Thinkphp 5应用目录(application)下的函数库common里写函数调用
common.php的完整代码如下:
<?php
// +----------------------------------------------------------------------
// | ThinkPHP [ WE CAN DO IT JUST THINK ]
// +----------------------------------------------------------------------
// | Copyright (c) 2006-2016 http://thinkphp.cn All rights reserved.
// +----------------------------------------------------------------------
// | Licensed ( http://www.apache.org/licenses/LICENSE-2.0 )
// +----------------------------------------------------------------------
// | Author: 流年 <liu21st@gmail.com>
// +----------------------------------------------------------------------
// 应用公共文件
// 首先在函数顶部引入阿里云短信的命名空间,无需修改,官方sdk自带的命名空间
use Aliyun\Core\Config;
use Aliyun\Core\Profile\DefaultProfile;
use Aliyun\Core\DefaultAcsClient;
use Aliyun\Api\Sms\Request\V20170525\SendSmsRequest;
/**
* 阿里发送短信函数
* @param $mobile int 手机号码
* @param $code int 自定义随机数
* @return mixed
*/
function sendMsg($mobile, $code)
{
// 引入autoload自动加载文件
require_once EXTEND_PATH . 'alisms/vendor/autoload.php';
Config::load(); // 加载区域结点配置
$accessKeyId = '×××××××××××××'; // TODO 阿里云短信获取的accessKeyId:修改成自己的
$accessKeySecret = '×××××××××××××'; // TODO 阿里云短信获取的accessKeySecret:修改成自己的
//模板内容中的变量赋值,$code要和模板内容中的对应上
//如模板中的内容为:你的验证码为:${code},该验证码5分钟内有效,请勿泄漏!
$templateParam = array("code" => $code); //模板变量替换
$signName = 'xxxxxxxxx'; //TODO 这个是短信签名,要审核通过:改成自己的
$templateCode = 'SMS_×××××××'; //短信模板ID,记得要审核通过的
//短信API产品名(短信产品名固定,无需修改)
$product = "Dysmsapi";
//短信API产品域名(接口地址固定,无需修改)
$domain = "dysmsapi.aliyuncs.com";
//暂时不支持多Region(目前仅支持cn-hangzhou请勿修改)
$region = "cn-hangzhou";
// 初始化用户Profile实例
$profile = DefaultProfile::getProfile($region, $accessKeyId, $accessKeySecret);
// 增加服务结点
DefaultProfile::addEndpoint("cn-hangzhou", "cn-hangzhou", $product, $domain);
// 初始化AcsClient用于发起请求
$acsClient = new DefaultAcsClient($profile);
// 初始化SendSmsRequest实例用于设置发送短信的参数
$request = new SendSmsRequest();
// 必填,设置雉短信接收号码
$request->setPhoneNumbers($mobile);
// 必填,设置签名名称
$request->setSignName($signName);
// 必填,设置模板CODE
$request->setTemplateCode($templateCode);
// 可选,设置模板参数
if ($templateParam) {
$request->setTemplateParam(json_encode($templateParam));
}
//发起访问请求
$acsResponse = $acsClient->getAcsResponse($request);
//返回请求结果
return json_decode(json_encode($acsResponse), true);
}
五、发送短信
直接在控制器里面调用sendMsg()方法即可
sendMsg(13751632107, 12345);