1. 程式人生 > >laravel中實現簡訊傳送驗證碼

laravel中實現簡訊傳送驗證碼

前段時間想實現一個簡訊驗證碼的功能,但是卡了很長時間。

首先我用的是阿里雲的簡訊服務業務,其首次接入流程如下:

在阿里雲上開通簡訊服務後需要做的:

1,申請簽名  2,申請模板   3,建立Accesskey ,值得說的是,可以通過阿里雲提供的子使用者進行Accesskey的建立,這樣可以更安全  4,充值

laravel有很多的進行簡訊業務的擴充套件包,之前我用的是阿里大於,使用如下:

1,從終端或者命令進入您的項,執行:composer require iscms/alisms-for-laravel

2,將:iscms\Alisms\AlidayuServiceProvider::class加入config\app.php的Providers下 類似:

3,執行:php artisan vendor:publish,這樣會在config資料夾下新增一個alisms.php檔案,內容如下:

<?php
    return [
        'KEY' =>env('ALISMS_KEY',null),
        'SECRETKEY'=>env('ALISMS_SECRETKEY',null),
    ];

 4,在.env檔案中寫入:

ALISMS_KEY=23305789

ALISMS_SECRETKEY=**************

 注意:ALISMS_KEY和ALISMS_SECRETKEY就是阿里雲生成的訪問祕鑰成對(AccessKeyId 與 AccessKeySecret)

開始使用:

 1,在您需要呼叫簡訊服務的控制器中引入SMS:

  use iscms\Alisms\SendsmsPusher as Sms;

    public function __construct(Sms $sms)
    {
       $this->sms=$sms;
    }

    public function index()
    {
       $result=$this->sms->send("$phone","$name","$content","$code");
    }

引數說明:$phone,$name,$content,$code
  1. $phone 指接受簡訊方的簡訊號碼,
  2. $content 是指簡訊模板中的變數內容.舉個例子
在自己的阿里大魚模板裡面有下面一個簡訊模板

模板名稱: 身份驗證驗證碼
模板ID: SMS_3910275 
*模板內容: 驗證碼${code},您正在進行${product}身份驗證,打死不要告訴別人哦!
那麼對應的我們的$content 就應該為
   {
      code:"生成的驗證碼",
      product:"示例專案"
    }


到此就可以正常使用,但是不知道為什麼,我在使用過程中,控制檯返回了code=11的錯誤碼,在淘寶上查證後是因為isv許可權的問題,之後我在阿里雲上將使用者的許可權控制開到了最大,但是依舊會出現這個錯誤,
換了一個擴充套件包還是這個問題,到現在還沒有解決,於是我就在laravel中寫原生的。

首先從阿里雲官網上下載關於簡訊服務的sdk包
SDK工具包中一共包含了2個類庫,一個aliyun-php-sdk-core包,另外一個是alicom-dysms-api包,將這兩個包新增到工程類庫中依賴。
選擇PHP版本的sdk包將壓縮包解壓,裡面有四個資料夾:api_demo,api_sdk,msg_demo,msg_sdk
在laravel專案的app資料夾下新建一個名為libs的資料夾,將api_sdk和msg_sdk複製到libs資料夾下。
找到根目錄下的composer.json檔案,找到composer.json中定義的classmap選項,寫入引入的兩個包:

終端進入專案資料夾中執行:composer dumpautoload
這樣子就在laravel中引入了第三方類庫。
建立程式碼檔案
我將其簡單的封裝了一下:
<?php


	// namespace App\Http\Controllers\sms;


	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;


	use App\Http\Controllers\Controller;




	// 載入區域結點配置
	Config::load();


	class SmsController extends Controller 
	{


		/**
		 * 構造器
		 * @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  [type] $phoneNumbers 必填, 簡訊接收號碼
		 * @param  string $signName    必填, 簡訊簽名,應嚴格"簽名名稱"填寫,
		 * @param  string $templateCode  必填, 簡訊模板Code,應嚴格按"模板CODE"填寫,
		 * @param  [type] $outId        選填, 假如模板中存在變數需要替換則為必填項
		 * @return [type]               [description]
		 */
		public function sendSms($phoneNumbers,$signName="XX軟體",$templateCode="SMS_XXXXXX",$outId=null)
		{


			 // 初始化SendSmsRequest例項用於設定傳送簡訊的引數
			$request = new SendSmsRequest;


			 // 必填,設定雉簡訊接收號碼
			$request->setPhoneNumbers($phoneNumbers);


			 // 必填,設定簽名名稱
			$request->setSignName($signName);


			// 必填,設定模板CODE
			$request->setTemplateCode($templateCode);


			$num = rand(100000,999999);


			 // 可選,設定模板引數
			$request->setTemplateParam(json_encode(
				Array(
					"code" => "$num"
				)
			));


			  // 可選,設定流水號
			if($outId) {
				$request->setOutId($outId);
			}


			 // 發起訪問請求
			$acsResponse = $this->acsClient->getAcsResponse($request);




		}


		/**
		 * 查詢簡訊傳送情況範例
		 * @param  [type]  $phoneNumbers 必填, 簡訊接收號碼
		 * @param  [type]  $sendDate     必填,簡訊傳送日期,格式Ymd,支援近30天記錄查詢 
		 * @param  integer $pageSize   必填,分頁大小
		 * @param  integer $currentPage  必填,當前頁碼
		 * @param  [type]  $bizId        選填,簡訊傳送流水號
		 * @return [type]                [description]
		 */
		public function queryDetails($phoneNumbers,$sendDate,$pageSize=10,$currentPage=1,$bizId=null)
		{


			 // 初始化QuerySendDetailsRequest例項用於設定簡訊查詢的引數
			$request = new QuerySendDetailsRequest();


			$request->setPhoneNumber($phoneNumbers);


			$request->setSendDate($sendDate);


			$request->setPageSize($pageSize);


			$request->setCurrentPage($currentPage);


			if($bizId) {
				$request->setBizId($bizId);
			}


			$acsResponse = $this->acsClient->getAcsResponse($request);


		}


	}


之後用就例項化呼叫方法就可以了。