>백엔드 개발 >PHP 튜토리얼 >최신 Alibaba Cloud SMS 서비스 인터페이스 클래스 [개인 테스트 성공]

최신 Alibaba Cloud SMS 서비스 인터페이스 클래스 [개인 테스트 성공]

PHP中文网
PHP中文网원래의
2018-05-29 17:37:067012검색

최신 Alibaba Cloud SMS 인터페이스는 Alibaba 이동 후 상황에 적합합니다.
저는 이전에 Alibaba Cloud의 SMS 인터페이스를 사용해 왔습니다. 최근 프로젝트를 진행하던 중 Alibaba Cloud가 조용히 Alibaba Cloud로 이전했다는 것을 알게 되었습니다. Alibaba Cloud에는 SDK 파일이 너무 많아서 혼란스럽습니다! 다음 코드는 Alibaba Cloud SMS 서비스에 적용 가능한 최신 클래스입니다. 개인 테스트에 성공했습니다!
마스터가 이전에 코드를 공개했지만 테스트 후 "SMS 인터페이스가 오류 코드를 반환합니다: InvalidDayuStatus.Malformed, 계정 SMS 활성화 상태가 올바르지 않습니다"라고 반환됩니다! (테스트 결과 이 ​​코드는 Alibaba 인터페이스에는 적합하지만 최신 Alibaba Cloud 콘솔의 SMS 서비스에는 적합하지 않습니다.)
SDK 소개를 자세히 검토한 후 링크 주소:
"안녕하세요. 다른 언어에는 SDK가 없습니다. ​​지금은 업데이트를 위해 열심히 노력하고 있으니 계속 지켜봐 주시기 바랍니다! SDK는 http 요청을 연결하고 반환 메시지를 구문 분석하는 데만 도움이 됩니다. SDK 버전을 컴파일할 수 없는 경우 직접 http 요청을 연결하여 사용할 수 있습니다. 인터페이스 자체는 단지 http 요청 호출일 뿐입니다. http 요청을 연결하려면 위 링크를 참조하거나 SDK의 소스 코드를 참조하세요. 다운로드하려면 클릭하세요

위 코드를 수정하세요. (주로 수신 매개변수와 게이트웨이를 수정합니다.)

<?php
/**
 * 阿里云短信验证码发送类
 * @author Administrator
 *
 */
class Sms {
    // 保存错误信息
    public $error;
    // Access Key ID
    private $accessKeyId = &#39;&#39;;
    // Access Access Key Secret
    private $accessKeySecret = &#39;&#39;;
    // 签名
    private $signName = &#39;&#39;;
    // 模版ID
    private $templateCode = &#39;&#39;;
    public function __construct($cofig = array()) {
        $cofig = array (
                &#39;accessKeyId&#39; => &#39;xxxxxxxxxxx&#39;,
                &#39;accessKeySecret&#39; => &#39;xxxxxxxxxx&#39;,
                &#39;signName&#39; => &#39;你的签名&#39;,
                &#39;templateCode&#39; => &#39;SMS_76510109&#39; 
        );
        // 配置参数
        $this->accessKeyId = $cofig [&#39;accessKeyId&#39;];
        $this->accessKeySecret = $cofig [&#39;accessKeySecret&#39;];
        $this->signName = $cofig [&#39;signName&#39;];
        $this->templateCode = $cofig [&#39;templateCode&#39;];
    }
    private function percentEncode($string) {
        $string = urlencode ( $string );
        $string = preg_replace ( &#39;/\+/&#39;, &#39;%20&#39;, $string );
        $string = preg_replace ( &#39;/\*/&#39;, &#39;%2A&#39;, $string );
        $string = preg_replace ( &#39;/%7E/&#39;, &#39;~&#39;, $string );
        return $string;
    }
    /**
     * 签名
     *
     * @param unknown $parameters            
     * @param unknown $accessKeySecret            
     * @return string
     */
    private function computeSignature($parameters, $accessKeySecret) {
        ksort ( $parameters );
        $canonicalizedQueryString = &#39;&#39;;
        foreach ( $parameters as $key => $value ) {
            $canonicalizedQueryString .= &#39;&&#39; . $this->percentEncode ( $key ) . &#39;=&#39; . $this->percentEncode ( $value );
        }
        $stringToSign = &#39;GET&%2F&&#39; . $this->percentencode ( substr ( $canonicalizedQueryString, 1 ) );
        $signature = base64_encode ( hash_hmac ( &#39;sha1&#39;, $stringToSign, $accessKeySecret . &#39;&&#39;, true ) );
        return $signature;
    }
    /**
     * @param unknown $mobile            
     * @param unknown $verify_code            
     *
     */
    public function send_verify($mobile, $verify_code) {
        $params = array (   //此处作了修改
                &#39;SignName&#39; => $this->signName,
                &#39;Format&#39; => &#39;JSON&#39;,
                &#39;Version&#39; => &#39;2017-05-25&#39;,
                &#39;AccessKeyId&#39; => $this->accessKeyId,
                &#39;SignatureVersion&#39; => &#39;1.0&#39;,
                &#39;SignatureMethod&#39; => &#39;HMAC-SHA1&#39;,
                &#39;SignatureNonce&#39; => uniqid (),
                &#39;Timestamp&#39; => gmdate ( &#39;Y-m-d\TH:i:s\Z&#39; ),
                &#39;Action&#39; => &#39;SendSms&#39;,
                &#39;TemplateCode&#39; => $this->templateCode,
                &#39;PhoneNumbers&#39; => $mobile,
                //&#39;TemplateParam&#39; => &#39;{"code":"&#39; . $verify_code . &#39;"}&#39; 
                &#39;TemplateParam&#39; => &#39;{"time":"1234"}&#39;   //更换为自己的实际模版
        );
        //var_dump($params);die;
        // 计算签名并把签名结果加入请求参数
        $params [&#39;Signature&#39;] = $this->computeSignature ( $params, $this->accessKeySecret );
        // 发送请求(此处作了修改)
        //$url = &#39;https://sms.aliyuncs.com/?&#39; . http_build_query ( $params );
        $url = &#39;http://dysmsapi.aliyuncs.com/?&#39; . http_build_query ( $params );
        
        $ch = curl_init ();
        curl_setopt ( $ch, CURLOPT_URL, $url );
        curl_setopt ( $ch, CURLOPT_SSL_VERIFYPEER, FALSE );
        curl_setopt ( $ch, CURLOPT_SSL_VERIFYHOST, FALSE );
        curl_setopt ( $ch, CURLOPT_RETURNTRANSFER, 1 );
        curl_setopt ( $ch, CURLOPT_TIMEOUT, 10 );
        $result = curl_exec ( $ch );
        curl_close ( $ch );
        $result = json_decode ( $result, true );
        //var_dump($result);die;
        if (isset ( $result [&#39;Code&#39;] )) {
            $this->error = $this->getErrorMessage ( $result [&#39;Code&#39;] );
            return false;
        }
        return true;
    }
    /**
     * 获取详细错误信息
     *
     * @param unknown $status            
     */
    public function getErrorMessage($status) {
        // 阿里云的短信 乱八七糟的(其实是用的阿里大于)
        // https://api.alidayu.com/doc2/apiDetail?spm=a3142.7629140.1.19.SmdYoA&apiId=25450
        $message = array (
                &#39;InvalidDayuStatus.Malformed&#39; => &#39;账户短信开通状态不正确&#39;,
                &#39;InvalidSignName.Malformed&#39; => &#39;短信签名不正确或签名状态不正确&#39;,
                &#39;InvalidTemplateCode.MalFormed&#39; => &#39;短信模板Code不正确或者模板状态不正确&#39;,
                &#39;InvalidRecNum.Malformed&#39; => &#39;目标手机号不正确,单次发送数量不能超过100&#39;,
                &#39;InvalidParamString.MalFormed&#39; => &#39;短信模板中变量不是json格式&#39;,
                &#39;InvalidParamStringTemplate.Malformed&#39; => &#39;短信模板中变量与模板内容不匹配&#39;,
                &#39;InvalidSendSms&#39; => &#39;触发业务流控&#39;,
                &#39;InvalidDayu.Malformed&#39; => &#39;变量不能是url,可以将变量固化在模板中&#39; 
        );
        if (isset ( $message [$status] )) {
            return $message [$status];
        }
        return $status;
    }
}

Call 성공적으로 코드는 다음과 같습니다:

  //生成验证码
    $mobile = &#39;xxxxxxx&#39;;
    $code = rand ( 1000, 9999 );
    //发送短信
    $sms = new Sms();
        
    //测试模式
    $status = $sms->send_verify($mobile, $code);
        
    if (!$status) {
        echo $sms->error;
    }
//看你这个封装的复杂些,不知道用的是不是同一个短信接口。
//上周有个客户用的是阿里大于的短信接口,看api文档,只要这么写就行了。
<?php
$c = new TopClient;
$c->appkey = $appkey;
$c->secretKey = $secret;
$req = new AlibabaAliqinFcSmsNumSendRequest;
$req->setExtend("123456");
$req->setSmsType("normal");
$req->setSmsFreeSignName("阿里大于");
$req->setSmsParam("{\"code\":\"1234\",\"product\":\"alidayu\"}");
$req->setRecNum("13000000000");
$req->setSmsTemplateCode("SMS_585014");
$resp = $c->execute($req);
?>

위 내용은 최신 Alibaba Cloud SMS 서비스 인터페이스 클래스 [개인 테스트 성공]의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.