一、开通阿里云短信服务

首先去阿里云官网,申请账号,并开通短信服务功能。

二、创建签名以及模板

1、创建签名

2、记住签名名称

 

3、创建模板

4、记住模板Code

、下载并集成PHP-SDK

从阿里云短信官网下载SDK(https://help.aliyun.com/document_detail/55359.html?spm=5176.8195934.507901.12.2NiZni)
将SDK放到thinkphp5框架的extend目录下, 如下图:

 

这里我已经自己精简了阿里云官方的SDK包,下载包在底部

然后再使用之前需要新建一个发送控制类,我这里就简单修改了一下官方的发送demo

代码如下 Alisms.php

<?php
/**
 * Created by 小羊.
 * Author: 勇敢的小笨羊
 * 微博: http://weibo.com/xuzuxing
 * Date: 2017/11/25
 * Time: 22:03
 */

namespace app\common\lib;
use Aliyun\Sms\Api\QuerySendDetailsRequest;
use Aliyun\Sms\Api\SendSmsRequest;
use Aliyun\Sms\Core\Config;
use Aliyun\Sms\Core\DefaultAcsClient;
use Aliyun\Sms\Core\Profile\DefaultProfile;

// 加载区域结点配置
Config::load();
class AliSms
{
    static $acsClient = null;

    /**
     * 取得AcsClient
     *
     * @return DefaultAcsClient
     */
    public static function getAcsClient() {
        //产品名称:云通信流量服务API产品,开发者无需替换
        $product = "Dysmsapi";

        //产品域名,开发者无需替换
        $domain = "dysmsapi.aliyuncs.com";

        // TODO 此处需要替换成开发者自己的AK (https://ak-console.aliyun.com/)
        $accessKeyId = config('aliyun.accessKeyId'); // AccessKeyId

        $accessKeySecret = config('aliyun.accessKeySecret'); // AccessKeySecret


        // 暂时不支持多Region
        $region = "cn-hangzhou";

        // 服务结点
        $endPointName = "cn-hangzhou";


        if(static::$acsClient == null) {

            //初始化acsClient,暂不支持region化
            $profile = DefaultProfile::getProfile($region, $accessKeyId, $accessKeySecret);

            // 增加服务结点
            DefaultProfile::addEndpoint($endPointName, $region, $product, $domain);

            // 初始化AcsClient用于发起请求
            static::$acsClient = new DefaultAcsClient($profile);
        }
        return static::$acsClient;
    }

    /**
     * 发送短信
     *
     * @param string $signName <p>
     * 必填, 短信签名,应严格"签名名称"填写,参考:<a href="https://dysms.console.aliyun.com/dysms.htm#/sign">短信签名页</a>
     * </p>
     * @param string $templateCode <p>
     * 必填, 短信模板Code,应严格按"模板CODE"填写, 参考:<a href="https://dysms.console.aliyun.com/dysms.htm#/template">短信模板页</a>
     * (e.g. SMS_0001)
     * </p>
     * @param string $phoneNumbers 必填, 短信接收号码 (e.g. 12345678901)
     * @param array|null $templateParam <p>
     * 选填, 假如模板中存在变量需要替换则为必填项 (e.g. Array("code"=>"12345", "product"=>"阿里通信"))
     * </p>
     * @param string|null $outId [optional] 选填, 发送短信流水号 (e.g. 1234)
     * @param string|null $smsUpExtendCode [optional] 选填,上行短信扩展码(扩展码字段控制在7位或以下,无特殊需求用户请忽略此字段)
     * @return stdClass
     */
    public static function sendSms($signName, $templateCode , $phoneNumbers, $templateParam = null, $outId = null, $smsUpExtendCode = null) {

        // 初始化SendSmsRequest实例用于设置发送短信的参数
        $request = new SendSmsRequest();

        // 必填,设置雉短信接收号码
        $request->setPhoneNumbers($phoneNumbers);

        // 必填,设置签名名称
        $request->setSignName($signName);

        // 必填,设置模板CODE
        $request->setTemplateCode($templateCode);

        // 可选,设置模板参数
        if($templateParam) {
            $request->setTemplateParam(json_encode($templateParam));
        }

        // 可选,设置流水号
        if($outId) {
            $request->setOutId($outId);
        }

        // 选填,上行短信扩展码
        if($smsUpExtendCode) {
            $request->setSmsUpExtendCode($smsUpExtendCode);
        }

        // 发起访问请求
        $acsResponse = static::getAcsClient()->getAcsResponse($request);

        // 打印请求结果
        //var_dump($acsResponse);

        return $acsResponse;

    }

    /**
     * 短信发送记录查询
     *
     * @param string $phoneNumbers 必填, 短信接收号码 (e.g. 12345678901)
     * @param string $sendDate 必填,短信发送日期,格式Ymd,支持近30天记录查询 (e.g. 20170710)
     * @param int $pageSize 必填,分页大小
     * @param int $currentPage 必填,当前页码
     * @param string $bizId 选填,短信发送流水号 (e.g. abc123)
     * @return stdClass
     */
    public function queryDetails($phoneNumbers, $sendDate, $pageSize = 10, $currentPage = 1, $bizId=null) {

        // 初始化QuerySendDetailsRequest实例用于设置短信查询的参数
        $request = new QuerySendDetailsRequest();

        // 必填,短信接收号码
        $request->setPhoneNumber($phoneNumbers);

        // 选填,短信发送流水号
        $request->setBizId($bizId);

        // 必填,短信发送日期,支持近30天记录查询,格式Ymd
        $request->setSendDate($sendDate);

        // 必填,分页大小
        $request->setPageSize($pageSize);

        // 必填,当前页码
        $request->setCurrentPage($currentPage);

        // 发起访问请求
        $acsResponse = static::getAcsClient()->getAcsResponse($request);

        // 打印请求结果
        // var_dump($acsResponse);

        return $acsResponse;
    }


}

 

发送短信代码如下:

/**
* 发送短信验证码
*/
public function sendCodeBySms($phoneNumber){

$signName = config('aliyun.signName');
$templateCode = config('aliyun.templateCode');
$code = getRandChar(6,'NUMBER');//生成验证码

$templateParam = [
'code' => $code
];

$ali = new AliSms();
//短信模板
$res = $ali->sendSms(
$signName,
$templateCode ,
$phoneNumber,
$templateParam,
$outId = null,
$smsUpExtendCode = null
);
halt($res);
if(!$res){
return show(0,'发送失败','');exit;
}

$uid = Token::getCurrentUid();
//存入缓存做验证
cache('verify_'.$uid,$code,300);
return show(1,'获取短信验证码成功',cache('verify_'.$uid));

}

发送效果:

 

下载地址:

链接:https://pan.baidu.com/s/1bqACNrL 密码:wqu7