這次帶給大家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
在自己的阿里大魚模板裡面有下面一個簡訊範本
範本名稱: 驗證驗證碼
範本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); } }
之后用就实例化调用方法就可以了。
相信看了本文案例你已经掌握了方法,更多精彩请关注php中文网其它相关文章!
推荐阅读:
PHP使用file_get_contents发送http请求步骤详解
以上是laravel操作簡訊發送驗證碼功能實現步驟詳解的詳細內容。更多資訊請關注PHP中文網其他相關文章!