最新阿里短信配置

来源:互联网 发布:海淘优惠信息网站 知乎 编辑:程序博客网 时间:2024/06/15 17:20
一,
$mobile = 'xxxxxx';  //手机号
$smsSign ='吴志路';  //签名
$website="天宝微拍";  //短信变量
$product="身份认证";  //短信变量
$code=mt_rand(1000,9999)  ;   //短信$code

$smsParam="{\"code\":\"${code}\",\"product\":\"{$product}\" ,\"website\":\"{$website}\"}";
$templateCode='SMS_114395007';
$flag =realApi_10SendSMS($mobile, $smsSign, $smsParam , $templateCode,$code);

二,
    function realApi_10SendSMS($mobile, $smsSign, $smsParam, $templateCode,$checkcode)
    {
        $config = tbCache('sms');   //获取appKey,secretKey
        //dump($config);exit;
        $demo = new AliyunSdkMsg(
            $config['sms_appkey'],
            $config['sms_secretKey']
        );
        $response = $demo->sendSms(
            $smsSign, // 短信签名
            $templateCode, // 短信模板编号
            $mobile, // 短信接收者
            Array(  // 短信模板中字段的值
                "code"=>$checkcode
            ),
            "123"
        );
        if ($response && isset($response->Code) && $response->Code =='OK') {
            return array('status' => 1, 'msg' => '发送成功');
        } else {
            return array('status' => -1, 'msg' => $response->Message??'');
        }

    }


三,
<?php
namespace app\dataapi\server;
ini_set("display_errors", "on");

require_once ROOT_PATH . 'vendor/api_sdk/vendor/autoload.php';

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;

class AliyunSdkMsg
{
    protected  $acsClient=null;
    /**
     * 构造器
     * @param string $accessKeyId 必填,AccessKeyId
     * @param string $accessKeySecret 必填,AccessKeySecret
     */
    public function __construct($accessKeyId, $accessKeySecret)
    {
        // 加载区域结点配置
        Config::load();
        // 短信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 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)
     * @return stdClass
     */
    public function sendSms($signName, $templateCode, $phoneNumbers, $templateParam = null, $outId = 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);
        }

        // 发起访问请求
        $acsResponse = $this->acsClient->getAcsResponse($request);

        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 = $this->acsClient->getAcsResponse($request);

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

        return $acsResponse;
    }

}
原创粉丝点击