1. 程式人生 > 程式設計 >php與阿里雲簡訊介面接入操作案例分析

php與阿里雲簡訊介面接入操作案例分析

本文例項講述了php與阿里雲簡訊介面接入操作。分享給大家供大家參考,具體如下:

使用阿里雲簡訊API,需要在控制檯獲取以下必要引數,其中需要自己手機驗證+官方稽核多次,尤其稽核需要保持耐心。

1. accessKeyId 相當於你的個人賬戶金鑰;

2. accessKeySecret 與上是成對的;

3. SignName 個人簽名,在發出去的簡訊中,這個簽名會顯示在開頭,類似 【簽名】親愛的使用者...... 這種格式,SignName需要通過提交稽核;

4.TemplateCode 模板程式碼,阿里雲簡訊是無法完全自定義簡訊的,需要通過稽核的模板,然後自己再替換掉模板中的變數,如模板:“您的驗證碼是$[code]”,code就是變數,使用時需設定變數值{"code":"12345"}(設定變數值的過程在demo中實現),簡訊發出去後變成:“您的驗證碼是12345”,每個通過稽核的模板會提供一個模板程式碼;

最新的阿里雲簡訊介面,適用於阿里大於搬家以後的情況。

之前一直用阿里大於的簡訊介面,最近上專案時發現阿里大於悄悄地搬家到了阿里雲!阿里雲的SDK檔案繁多,看得一頭霧水!下面程式碼是最新的可適用於阿里雲簡訊服務的類,親測成功!

<?php
/**
 * 阿里雲簡訊驗證碼傳送類
 * @author Administrator
 *
 */
class Sms {

  // 儲存錯誤資訊

  public $error;

  // Access Key ID

  private $accessKeyId = '';

  // Access Access Key Secret

  private $accessKeySecret = '';

  // 簽名

  private $signName = '';

  // 模版ID

  private $templateCode = '';

  public function __construct($cofig = array()) {

    $cofig = array (

        'accessKeyId' => 'xxxxxxxxxxx','accessKeySecret' => 'xxxxxxxxxx','signName' => '你的簽名','templateCode' => 'SMS_76510109'

    );

    // 配置引數

    $this->accessKeyId = $cofig ['accessKeyId'];

    $this->accessKeySecret = $cofig ['accessKeySecret'];

    $this->signName = $cofig ['signName'];

    $this->templateCode = $cofig ['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;

  }

  /**
   * @param unknown $mobile      
   * @param unknown $verify_code      
   *
   */

  public function send_verify($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 . '"}' 

        'TemplateParam' => '{"time":"1234"}'  //更換為自己的實際模版

    );

    //var_dump($params);die;

    // 計算簽名並把簽名結果加入請求引數

    $params ['Signature'] = $this->computeSignature ( $params,$this->accessKeySecret );

    // 傳送請求(此處作了修改)

    //$url = 'https://sms.aliyuncs.com/?' . http_build_query ( $params );

    $url = 'http://dysmsapi.aliyuncs.com/?' . 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,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 ['Code'] )) {

      $this->error = $this->getErrorMessage ( $result ['Code'] );

      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 (

        'InvalidDayuStatus.Malformed' => '賬戶簡訊開通狀態不正確','InvalidSignName.Malformed' => '簡訊簽名不正確或簽名狀態不正確','InvalidTemplateCode.MalFormed' => '簡訊模板Code不正確或者模板狀態不正確','InvalidRecNum.Malformed' => '目標手機號不正確,單次傳送數量不能超過100','InvalidParamString.MalFormed' => '簡訊模板中變數不是json格式','InvalidParamStringTemplate.Malformed' => '簡訊模板中變數與模板內容不匹配','InvalidSendSms' => '觸發業務流控','InvalidDayu.Malformed' => '變數不能是url,可以將變數固化在模板中'

    );

    if (isset ( $message [$status] )) {

      return $message [$status];

    }

    return $status;

  }

}

呼叫方法:

//生成驗證碼
$mobile = 'xxxxxxx';
$code = rand ( 1000,9999 );
//傳送簡訊
$sms = new Sms();

//測試模式
$status = $sms->send_verify($mobile,$code);
if (!$status) {
 echo $sms->error;

}

更多關於PHP相關內容感興趣的讀者可檢視本站專題:《PHP程序與執行緒操作技巧總結》、《PHP網路程式設計技巧總結》、《PHP基本語法入門教程》、《PHP陣列(Array)操作技巧大全》、《php字串(string)用法總結》、《php+mysql資料庫操作入門教程》及《php常見資料庫操作技巧彙總》

希望本文所述對大家PHP程式設計有所幫助。