laravel+阿里大于实现发送验证码短信

时间:2021-09-28 14:13:06

一、短信服务使用阿里大于提供的短信接口

阿里大于官方网站上的接入流程:

laravel+阿里大于实现发送验证码短信

在阿里大于申请接口后,需要做以下操作:

  1. 申请签名
  2. 申请短信模板
  3. 创建Accesskey,可以通过权限最大的Accesskey创建子Accesskey,便于权限控制
  4. 充值,如果账户中余额不足的话,是发布出去短信的

二、在laravel中使用阿里大于接口

之前在laravel中使用composer安装阿里大于的扩展包,但是尝试之后,一直返回code=11的错误码,是扩展包的权限不足,具体原因还未找到

然后就在laravel引入官方提供的skd包,下面介绍具体在laravel中使用官方sdk包的过程:

  1. 从官网上下载php版短信服务的skd包,解压后有四个文件夹,分别是:api_demo,api_sdk,msg_demo,msg_sdk
  2. 在laravel中根目录下的 app文件夹下新建一个文件夹 libs,把api_sdk和msg_sdk复制到libs文件夹下.
  3. 利用composer自动加载文件     关于laravel利用composer自动加载介绍,请参考:http://laravelacademy.org/post/7074.html
  4. 找到项目根目录下的composer.json文件,利用composer的classmap选项加载
    laravel+阿里大于实现发送验证码短信

    然后执行 composer dumpautoload

  5. 代码:
    1.  <?php
      
         //use 命名空间+类名
      
           use Aliyun\Core\Config;  //命名空间 Aliyun\Core  类名是 Config  (命名空间不必一定存在)
      use Aliyun\Core\Profile\DefaultProfile;
      use Aliyun\Core\DefaultAcsClient;
      use Aliyun\Api\Sms\Request\V20170525\SendSmsRequest;
      use Aliyun\Api\Sms\Request\V20170525\QuerySendDetailsRequest; use App\Http\Controllers\Controller; // 加载区域结点配置
      Config::load(); class SmsController extends Controller
      { /**
      * 构造器
      * @param string $accessKeyId 必填,AccessKeyId
      * @param string $accessKeySecret 必填,AccessKeySecret
      */
      public function __construct($accessKeyId="######",$accessKeySecret="#######")
      { // 短信API产品名
      $product = "Dysmsapi"; // 短信API产品域名
      $domain = "dysmsapi.aliyuncs.com"; // 暂时不支持多Region
      $region = "cn-hangzhou"; // 服务结点
      $endPointName = "cn-hangzhou"; // 初始化用户Profile实例
      $profile = DefaultProfile::getProfile($region, $accessKeyId, $accessKeySecret); // 增加服务结点
      DefaultProfile::addEndpoint($endPointName, $region, $product, $domain); // 初始化AcsClient用于发起请求
      $this->acsClient = new DefaultAcsClient($profile); } /**
      * 发送短信范例
      * @param [type] $phoneNumbers 必填, 短信接收号码
      * @param string $signName 必填, 短信签名,应严格"签名名称"填写,
      * @param string $templateCode 必填, 短信模板Code,应严格按"模板CODE"填写,
      * @param [type] $outId 选填, 假如模板中存在变量需要替换则为必填项
      * @return [type] [description]
      */
      public function sendSms($phoneNumbers,$signName="XX软件",$templateCode="SMS_XXXXXX",$outId=null)
      { // 初始化SendSmsRequest实例用于设置发送短信的参数
      $request = new SendSmsRequest; // 必填,设置雉短信接收号码
      $request->setPhoneNumbers($phoneNumbers); // 必填,设置签名名称
      $request->setSignName($signName); // 必填,设置模板CODE
      $request->setTemplateCode($templateCode); $num = rand(100000,999999); // 可选,设置模板参数
      $request->setTemplateParam(json_encode(
      Array(
      "code" => "$num"
      )
      )); // 可选,设置流水号
      if($outId) {
      $request->setOutId($outId);
      } // 发起访问请求
      $acsResponse = $this->acsClient->getAcsResponse($request); } /**
      * 查询短信发送情况范例
      * @param [type] $phoneNumbers 必填, 短信接收号码
      * @param [type] $sendDate 必填,短信发送日期,格式Ymd,支持近30天记录查询
      * @param integer $pageSize 必填,分页大小
      * @param integer $currentPage 必填,当前页码
      * @param [type] $bizId 选填,短信发送流水号
      * @return [type] [description]
      */
      public function queryDetails($phoneNumbers,$sendDate,$pageSize=10,$currentPage=1,$bizId=null)
      { // 初始化QuerySendDetailsRequest实例用于设置短信查询的参数
      $request = new QuerySendDetailsRequest(); $request->setPhoneNumber($phoneNumbers); $request->setSendDate($sendDate); $request->setPageSize($pageSize); $request->setCurrentPage($currentPage); if($bizId) {
      $request->setBizId($bizId);
      } $acsResponse = $this->acsClient->getAcsResponse($request); } }
      之后用就实例化调用方法就可以了。

本文参考:http://blog.csdn.net/lishanleilixin/article/details/78126955