您现在的位置是:首页> 网站开发> ThinkPHP

Thinkphp5整合阿里大鱼的方法超级教程看了就能用.

  • 4394人已阅读
  • 时间:2018-10-16 09:03:26
  • 分类:ThinkPHP
  • 作者:祥哥

阿里大鱼官网下载完整SDK包:

https://help.aliyun.com/document_detail/55359.html?spm=5176.doc55451.6.580.3rgXTq

下载目录如下:

SDK工具包目录结构如下:
    \_api_demo
    |   \_SmsDemo.php        短信服务相关接口demo示例
    \_api_sdk
    |   \_lib
    |   |   \_Api            包含Api接口请求体的封装
    |   |   \_Core            包含签名生成、Region配置等封装
    |   \_test                单元测试
    |   \_vendor            composer依赖打包
    \_msg_demo
    |   \_lib                示例依赖项
    |   \_MsgDemo.php        短信服务状态报告demo示例
    \_msg_sdk
      \_lib
      |   \_Api                包含Api接口请求体的封装
      |   \_Core            包含签名生成、Region配置等等封装
      |   \_MNS                包含消息服务相关封装
      \_test                单元测试
      \_vendor                composer依赖打包

我们整合只需要api-sdk复制出来到tp5的extend下面.我们可以对文件夹进行重命名.

接下来介绍两种方法使用.

第一种:直接在应用目录下的函数库common里写函数调用

首先在函数顶部引入阿里云短信的命名空间,无需修改,官方sdk自带的命名空间
use Aliyun\Core\Config;
use Aliyun\Core\Profile\DefaultProfile;
use Aliyun\Core\DefaultAcsClient;
use Aliyun\Api\Sms\Request\V20170525\SendSmsRequest;

//阿里短信函数,$mobile为手机号码,$code为自定义随机数
function sendMsg($mobile,$code){

    //这里的路径EXTEND_PATH就是指tp5根目录下的extend目录,系统自带常量。alisms为我们复制api_sdk过来后更改的目录名称
    require_once EXTEND_PATH.'alisms/vendor/autoload.php';
    Config::load();             //加载区域结点配置

    $accessKeyId = '×××××××××××××';  //阿里云短信获取的accessKeyId

    $accessKeySecret = '×××××××××××××';    //阿里云短信获取的accessKeySecret

    //这个个是审核过的模板内容中的变量赋值,记住数组中字符串code要和模板内容中的保持一致
    //比如我们模板中的内容为:你的验证码为:${code},该验证码5分钟内有效,请勿泄漏!
    $templateParam = array("code"=>$code);           //模板变量替换

    $signName = '浪博电子'; //这个是短信签名,要审核通过

    $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);

    //返回请求结果
    $result = json_decode(json_encode($acsResponse),true);
    return $result;
}

然后我们在控制器中方法直接调用使用,代码如下:

/*
         * 前台ajax请求发送短信验证码
         */
        public function sendSms($phone)
        {
            $mobile = $phone;
            //$code = 1111;
            $code = mt_rand(10000, 99999);
            $result = sendMsg($mobile, $code);
            //$result['Code'] = 'OK';
            if ($result['Code'] == 'OK') {
                //存到缓存当中,并且返回json数据给前端
                cache('tel' . $mobile, $code, 39);
                return json(['success' => 'ok', 'tel' => $mobile]);
            }
        }
[/code]
如果发送成功,将返回以下内容,当然你也可以自定义输出$sms为数组格式或者json格式
[code]array(4) {
  ["Message"] => string(2) "OK"
  ["RequestId"] => string(36) "5340C2E9-6802-4EA6-90E3-392518495E6A"
  ["BizId"] => string(20) "519300710627122289^0"
  ["Code"] => string(2) "OK"
}

第二种方法:我们直接在extend下面的alisms目录下写一个类

<?php
/**
 * Created by pan.
 * User: pan
 * Date: 2017/11/14
 * Time: 9:41
 */

//[b]命名空间为alisms[/b]
namespace alisms;

//引入sdk的命名空间
use Aliyun\Core\Config;
use Aliyun\Core\Profile\DefaultProfile;
use Aliyun\Core\DefaultAcsClient;
use Aliyun\Api\Sms\Request\V20170525\SendSmsRequest;

//引入autoload.php,EXTEND_PATH就是指tp5根目录下的extend目录,系统自带常量。alisms为我们复制api_sdk过来后更改的目录名称
require_once EXTEND_PATH.'alisms/vendor/autoload.php';
Config::load();             //加载区域结点配置


class SendSms
{
    //关键的配置,我们用成员属性
    public $accessKeyId = null; //阿里云短信获取的accessKeyId
    public $accessKeySecret = null; //阿里云短信获取的accessKeySecret
    public $signName = null;    //短信签名,要审核通过
    public $templateCode = null;    //短信模板ID,记得要审核通过的

    public function send($mobile,$templateParam)
    {
        //获取成员属性
        $accessKeyId     = $this->accessKeyId;
        $accessKeySecret = $this->accessKeySecret;
        $signName        = $this->signName;
        $templateCode    = $this->templateCode;
        //短信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);

        //返回请求结果,这里为为数组格式
        $result = json_decode(json_encode($acsResponse),true);
        return $result;
    }

}

然后在方法中写函数调用,或者直接在控制器中使用,这里为在控制器调用

namespace app\index\controller;

use think\Request;

//[b]记得引入命名空间,如果这里不引入命名空间,那么方法中的实例化SendSms的格式应该为:$sms = new \alisms\SendSms()[/b]
use alisms\SendSms;

class Index extends Base
{
    public function index()
    {
         //获取对象,如果上面没有引入命名空间,可以这样实例化:$sms = new \alisms\SendSms()
        $sms = new SendSms();
        //设置关键的四个配置参数,其实配置参数应该写在公共或者模块下的config配置文件中,然后在获取使用,这里我就直接使用了。
        $sms->accessKeyId = '××××××××';
        $sms->accessKeySecret = '×××××××××';
        $sms->signName = '浪博电子';
        $sms->templateCode = 'SMS_×××××××';
        
        //$mobile为手机号
        $mobile = '×××××××';
        //模板参数,自定义了随机数,你可以在这里保存在缓存或者cookie等设置有效期以便逻辑发送后用户使用后的逻辑处理
        $code = mt_rand();
        $templateParam = array("code"=>$code);
        $m = $sms->send($mobile,$templateParam);
        //类中有说明,默认返回的数组格式,如果需要json,在自行修改类,或者在这里将$m转换后在输出
        dump($m);
    }
}

至此绍束,至于发送后使用的业务逻辑,就要结合你自己实际的业务场景了.

Top