laravel5接入阿里云短信验证码服务

阿里云开通短信服务

地址

要申请两个东西

  • 短信签名
  • 短信模板
  • 申请短信签名
    在这里插入图片描述
    申请完,审核时间一般两个小时以内,挺快的。

审核状态变为通过,即为审核成功。

申请短信模板
在这里插入图片描述
里面的 ${code} 在之后调用api的时候是需要传进去的。
在这里插入图片描述
模板里的code也是调用api的时候要使用到的。

创建用户

调用短信服务的api,还需要两个参数

  • AccessKeyId
  • AccessKeySecret
    因此还需要去访问控制里创建一个用户,并分配 AliyunDysmsFullAccess 管理短信服务(SMS)的权限
    在这里插入图片描述
    创建好的时候记得保存 AccessKeySecret,之后就没机会再查看了。
    整合到Laravel框架
    手动整合
    ??? SDK及DEMO下载

Laravel整合的时候 也碰到各种各样的问题。
在这里插入图片描述
把下载的包里面的 api_sdk/lib/Core 和 api_sdk/lib/Api复制一份放到项目 app/libs/Aliyun 下,没有 libs 文件夹就新建。
在这里插入图片描述

然后打开项目根目录下的 composer.json 文件,找到下面的位置 classmap,加上图示代码

在这里插入图片描述

然后终端(Terminal)进入项目根目录,执行

composer dumpautoload

执行后若出现如下图所示,则表示更新成功
在这里插入图片描述

然后就可以直接使用sdk里面导入包的方式了。
在这里插入图片描述

真正做的时候也不是这样一帆风顺的,官方的sdk和demo本身也有些问题。
在这里插入图片描述
Invalid argument supplied for foreach()

直接把Demo复制过来,就会出现这样的问题

查了很多地方,发现是少了一句demo里少了一行代码

在 SmsController.getAcsClient() 里补上(原来是没的)

EndpointConfig::load();

在这里插入图片描述

Can not find endpoint to access.
天真的以为问题都解决了,结果马上出来另外一个问题。

在这里插入图片描述

找来源发现问题在这里 app/libs/Aliyun/Core/DefaultAcsClient.doActionImpl(),是程序主动抛出的错误。

在这里插入图片描述

回去看看这个 $domain 是什么,结果官方注释说 $domain是产品域名,开发者无需替换。我都没替换,你报个什么错啊。

在这里插入图片描述

算了,既然不需要,那就直接这里吧 $domain 写死好了。

$domain = 'dysmsapi.aliyuncs.com';

在这里插入图片描述
具体实现
我就把 smsDemo 里的几个方法都移到 SmsController 里了,

<?php
namespace App\Http\Controllers;

use Illuminate\Http\Request;
use Illuminate\Support\Facades\DB;

use 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 Aliyun\Core\Regions\EndpointConfig;

class SmsController extends Controller{

    // 可供调用的发送验证码api
    public function send(Request $request){
        header('Content-Type: text/plain; charset=utf-8');
        $phone = $request->input('phone');
        $code = $this::randomKeys(); // 随机生成6位数字验证码
        $response = SmsController::sendSms(
            "富春江app", // 短信签名
            "SMS_111785732", // 短信模板编号
            $phone, // 短信接收者
            Array(  // 短信模板中字段的值
              "code"=>$this::randomKeys(),
            ),
            "123456"   // 流水号,选填
        );
        $row = [];
        if($response->Code=='OK'){
            $row = ['status'=>1,'code'=>$code];
        }else{
            $row = ['status'=>0,'code'=>$response->Code,'message'=>$response->Message];
        }        
        $row = ['status'=>1,'code'=>$code];
        return json_encode($row);
    }

    
    // 随机生成6位数字验证码
    public function randomKeys($length = 6){
        $key='';
        $pattern='1234567890';
        for($i=0;$i<$length;++$i){
            $key .= $pattern{mt_rand(0,9)};    // 生成php随机数
        }
        return $key;
    }

    static $acsClient = null;

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

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

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

        $accessKeySecret = "EY9OdjeinAnEOeDyFNZb2OiT3Xg4ep"; // AccessKeySecret


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

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


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

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

            EndpointConfig::load();
            // 增加服务结点
            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;
    }
}

分享
laravel

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值