• 【短信接口】阿里大于迁移到阿里云之后使用方法


    之前阿里大于短信用着挺爽的,也挺方便,,自从迁移到阿里云之后,各种不好找,虽然功能强大了。体验太差了

    PS: 之前我自己玩在阿里大于充了五块钱的短信,后来找不到了。虽是小钱,但是他们却没处理好。

    特写此笔记,指引你前行!

    1  首先下载 短信接口SDK

    https://help.aliyun.com/document_detail/55359.html?spm=5176.doc56189.6.569.B9djtA

    解压 文件目录如下: 

    2 部署:

       api_sdk  是整个文档的库文件,留存,

      进入api_demo 文件夹  ,把这个文件复制一份出来 :smsdemo.php,命名: Alisms.class.php 

     把文件里下方的调用实例删除

     最终形成的目录:  sms 文件夹

    Alisms.class.php文件内容: 绿色部分我修改过,可根据项目自行修改路径

    <?php
    
    ini_set("display_errors", "on");
    
    require_once (ROOT_PATH . 'sms/api_sdk/vendor/autoload.php');
    use AliyunCoreConfig;
    use AliyunCoreProfileDefaultProfile;
    use AliyunCoreDefaultAcsClient;
    use AliyunApiSmsRequestV20170525SendSmsRequest;
    use AliyunApiSmsRequestV20170525QuerySendDetailsRequest;
    
    // 加载区域结点配置
    Config::load();
    
    /**
     * Class Sms
     *
     * athor: 依然范儿特西
     * todo: 阿里大于短信接口
     */
    class Alisms
    {
    
        /**
         * 构造器
         *
         * @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 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);
    
            // 打印请求结果
            // 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 = $this->acsClient->getAcsResponse($request);
    
            // 打印请求结果
            // var_dump($acsResponse);
    
            return $acsResponse;
        }
    
    }

     3 调用实例: 绿色部分修改过,要根据你短信模板的值来改

    /* 发送手机验证码 */
        require_once (ROOT_PATH . 'sms/Alisms.class.php');
        header('Content-Type: text/plain; charset=utf-8');
        $demo = new Alisms(
            "",  // AccessKeyID
            ""   //AccessKeySecret
        );
        $mobile_code =""; //验证码
        $response = $demo->sendSms(
            "", // 短信签名
            "", // 短信模板编号
            "", // 短信接收者,多个手机号用英文逗号隔开
            Array(  // 短信模板中字段的值
                "number"=>$mobile_code
            ),
            "123"
        );
    
        $result = $response->Code;
        if($result == 'OK'){
    echo "success";
      }else{
    echo "fail";
      }
  • 相关阅读:
    spring 常用注解
    自定义Repository
    Python生成连续数字的多种方式
    HTML&CSS学习笔记
    ZigBee学习笔记
    Win10系统采用虚拟机安装Ubuntu18.04进行NS3开发环境配置
    Git速查笔记
    历史向网址收藏
    图解设计模式转载
    Crush Course 统计学笔记
  • 原文地址:https://www.cnblogs.com/richerdyoung/p/7363574.html
Copyright © 2020-2023  润新知