wujf-myblog
<?php

/**
 * 阿里云短信验证码发送类
 */
class Util_AliyunSms
{
    // 保存错误信息
    public $error;
    // Access Key ID
    private $accessKeyId = \'\';
    // Access Access Key Secret
    private $accessKeySecret = \'\';
    // 签名
    private $signName = \'\';
    // 模版ID
    private $templateCode = \'\';

    public function __construct($config = array())
    {
        //新配置
        $config = array(
            \'accessKeyId\' => \'LTAI5tHwAGgXXXXXXXXXXX\',
            \'accessKeySecret\' => \'VGdydLxHwfAlH6W4XXXXXXXXXX\',
            \'signName\' => \'集印猫\',
            \'templateCode\' => \'SMS_190145146\'    // 身份验证验证码短信模板
        );
        // 配置参数
        $this->accessKeyId = $config [\'accessKeyId\'];
        $this->accessKeySecret = $config [\'accessKeySecret\'];
        $this->signName = $config [\'signName\'];
        $this->templateCode = $config [\'templateCode\'];
    }

    private function percentEncode($string)
    {
        $string = urlencode($string);
        $string = preg_replace(\'/\+/\', \'%20\', $string);
        $string = preg_replace(\'/\*/\', \'%2A\', $string);
        $string = preg_replace(\'/%7E/\', \'~\', $string);
        return $string;
    }

    /**
     * 签名
     *
     * @param unknown $parameters
     * @param unknown $accessKeySecret
     * @return string
     */
    private function computeSignature($parameters, $accessKeySecret)
    {
        ksort($parameters);
        $canonicalizedQueryString = \'\';
        foreach ($parameters as $key => $value) {
            $canonicalizedQueryString .= \'&\' . $this->percentEncode($key) . \'=\' . $this->percentEncode($value);
        }
        $stringToSign = \'GET&%2F&\' . $this->percentencode(substr($canonicalizedQueryString, 1));
        $signature = base64_encode(hash_hmac(\'sha1\', $stringToSign, $accessKeySecret . \'&\', true));
        return $signature;
    }

    /**
     * 发送验证码
     * https://help.aliyun.com/document_detail/44362.html?spm=5176.doc44364.2.1.LeeHSH
     * @param unknown $mobile
     * @param unknown $verify_code
     *
     */
    public function sendVerify($mobile, $verify_code)
    {
        $params = array(
            // 公共参数
            \'SignName\' => $this->signName,
            \'Format\' => \'JSON\',
            \'Version\' => \'2017-05-25\',
            \'AccessKeyId\' => $this->accessKeyId,
            \'SignatureVersion\' => \'1.0\',
            \'SignatureMethod\' => \'HMAC-SHA1\',
            \'SignatureNonce\' => uniqid (),
            \'Timestamp\' => gmdate ( \'Y-m-d\TH:i:s\Z\' ),
            \'Action\' => \'SendSms\',
            \'TemplateCode\' => $this->templateCode,
            \'PhoneNumbers\' => $mobile,
            \'TemplateParam\' => \'{"code":"\' . $verify_code . \'"}\'
        );

        // 计算签名并把签名结果加入请求参数
        $params [\'Signature\'] = $this->computeSignature($params, $this->accessKeySecret);
        // 发送请求
        Util_Log::write(Util_Log::LOG_TYPE_INFO,\'======发送短信参数=====\'.json_encode($params));
        //$url = \'https://sms.aliyuncs.com/?\' . http_build_query($params);
        $url = \'https://dysmsapi.aliyuncs.com/?\' . http_build_query($params);
        Util_Log::write(Util_Log::LOG_TYPE_INFO,\'======发送短信url=====\'.$url);
        $result = Util_Request::request($url);
        Util_Log::write(Util_Log::LOG_TYPE_INFO,\'======发送短信结果=====\'.$result);
        $result = json_decode($result, true);
        if (isset ($result [\'Code\'])) {
            $this->error = $this->getErrorMessage($result [\'Code\']);
            if($this->error != \'OK\'){
                return false;
            }
        }
        return true;
    }

    public function send($mobile, $templateCode, $paramString, $signName = \'\')
    {
        $params = array(
            // 公共参数
            \'SignName\' => $this->signName,
            \'Format\' => \'JSON\',
            \'Version\' => \'2017-05-25\',
            \'AccessKeyId\' => $this->accessKeyId,
            \'SignatureVersion\' => \'1.0\',
            \'SignatureMethod\' => \'HMAC-SHA1\',
            \'SignatureNonce\' => uniqid (),
            \'Timestamp\' => gmdate ( \'Y-m-d\TH:i:s\Z\' ),
            \'Action\' => \'SendSms\',
            \'TemplateCode\' => $templateCode,
            \'PhoneNumbers\' => $mobile,
            \'TemplateParam\' => $paramString,
        );
        // 计算签名并把签名结果加入请求参数
        $params [\'Signature\'] = $this->computeSignature($params, $this->accessKeySecret);
        // 发送请求
        $url = \'https://sms.aliyuncs.com/?\' . http_build_query($params);
        $result = Util_Request::request($url);
        $result = json_decode($result, true);
        Util_Log::write(Util_Log::LOG_TYPE_INFO, $result);
        if (isset ($result [\'Code\'])) {
            $this->error = $this->getErrorMessage($result [\'Code\']);
            if($this->error != \'OK\'){
                return false;
            }
        }
        return true;
    }

    /**
     * 获取详细错误信息
     *
     * @param unknown $status
     */
    private function getErrorMessage($status)
    {
        // 阿里云的短信 乱八七糟的(其实是用的阿里大于)
        // https://help.aliyun.com/document_detail/44364.html
        $message = array(
            \'InvalidDayuStatus.Malformed\' => \'账户短信开通状态不正确\',
            \'InvalidSignName.Malformed\' => \'短信签名不正确或签名状态不正确\',
            \'InvalidTemplateCode.MalFormed\' => \'短信模板Code不正确或者模板状态不正确\',
            \'InvalidRecNum.Malformed\' => \'目标手机号不正确,单次发送数量不能超过100\',
            \'InvalidParamString.MalFormed\' => \'短信模板中变量不是json格式\',
            \'InvalidParamStringTemplate.Malformed\' => \'短信模板中变量与模板内容不匹配\',
            \'InvalidSendSms\' => \'触发业务流控\',
            \'InvalidDayu.Malformed\' => \'变量不能是url,可以将变量固化在模板中\',
            \'InvalidAction.NotFound\' => \'接口地址不存在,请检查参数或地址\',
        );
        if (isset ($message [$status])) {
            return $message [$status];
        }
        return $status;
    }
}

  上面是通用接口类,调用方法如如下:

<?php
$verify_code = rand(100000, 999999); //随机生成verify_code
$sms = new Util_AliyunSms(); //新建发送短信对象
$res = $sms->sendVerify($mobile, $verify_code);
if(!$res) return false;    
return true;

  

分类:

技术点:

相关文章: