前言
前段時(shí)間想實(shí)現(xiàn)一個(gè)短信驗(yàn)證碼的功能,但是卡了很長時(shí)間。
首先我用的是阿里云的短信服務(wù)業(yè)務(wù),其首次接入流程如下:
在阿里云上開通短信服務(wù)后需要做的:
1,申請簽名 2,申請模板 3,創(chuàng)建Accesskey ,值得說的是,可以通過阿里云提供的子用戶進(jìn)行Accesskey的創(chuàng)建,這樣可以更安全 4,充值
laravel有很多的進(jìn)行短信業(yè)務(wù)的擴(kuò)展包,之前我用的是阿里大于,使用如下:
1,從終端或者命令進(jìn)入您的項(xiàng),運(yùn)行:composer require iscms/alisms-for-laravel
2,將:iscms\Alisms\AlidayuServiceProvider::class
加入config\app.php的Providers下 類似:
3,運(yùn)行:php artisan vendor:publish
,這樣會(huì)在config文件夾下新增一個(gè)alisms.php文件,內(nèi)容如下:
?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,在您需要調(diào)用短信服務(wù)的控制器中引入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");
}
參數(shù)說明:$phone,$name,$content,$code
- $phone 指接受短信方的短信號(hào)碼,
- $name 指短信簽名 可以在阿里大魚短信簽名 http://www.alidayu.com/admin/service/sign 找到
- $content 是指短信模板中的變量內(nèi)容.舉個(gè)例子
在自己的阿里大魚模板里面有下面一個(gè)短信模板
模板名稱: 身份驗(yàn)證驗(yàn)證碼
模板ID: SMS_3910275
*模板內(nèi)容: 驗(yàn)證碼$[code],您正在進(jìn)行${product}身份驗(yàn)證,打死不要告訴別人哦!
那么對應(yīng)的我們的$content 就應(yīng)該為
{
code:"生成的驗(yàn)證碼",
product:"示例項(xiàng)目"
}
到此就可以正常使用,但是不知道為什么,我在使用過程中,控制臺(tái)返回了code=11的錯(cuò)誤碼,在淘寶上查證后是因?yàn)閕sv權(quán)限的問題,之后我在阿里云上將用戶的權(quán)限控制開到了最大,但是依舊會(huì)出現(xiàn)這個(gè)錯(cuò)誤,換了一個(gè)擴(kuò)展包還是這個(gè)問題,到現(xiàn)在還沒有解決,于是我就在laravel中寫原生的。
首先從阿里云官網(wǎng)上下載關(guān)于短信服務(wù)的sdk包
SDK工具包中一共包含了2個(gè)類庫,一個(gè)aliyun-php-sdk-core包,另外一個(gè)是alicom-dysms-api包,將這兩個(gè)包添加到工程類庫中依賴。
選擇PHP版本的sdk包將壓縮包解壓,里面有四個(gè)文件夾:api_demo,api_sdk,msg_demo,msg_sdk
在laravel項(xiàng)目的app文件夾下新建一個(gè)名為libs的文件夾,將api_sdk和msg_sdk復(fù)制到libs文件夾下。
找到根目錄下的composer.json文件,找到composer.json中定義的classmap選項(xiàng),寫入引入的兩個(gè)包:
終端進(jìn)入項(xiàng)目文件夾中運(yùn)行:
這樣子就在laravel中引入了第三方類庫。
創(chuàng)建代碼文件
我將其簡單的封裝了一下:
?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;
// 加載區(qū)域結(jié)點(diǎn)配置
Config::load();
class SmsController extends Controller
{
/**
* 構(gòu)造器
* @param string $accessKeyId 必填,AccessKeyId
* @param string $accessKeySecret 必填,AccessKeySecret
*/
public function __construct($accessKeyId="######",$accessKeySecret="#######")
{
// 短信API產(chǎn)品名
$product = "Dysmsapi";
// 短信API產(chǎn)品域名
$domain = "dysmsapi.aliyuncs.com";
// 暫時(shí)不支持多Region
$region = "cn-hangzhou";
// 服務(wù)結(jié)點(diǎn)
$endPointName = "cn-hangzhou";
// 初始化用戶Profile實(shí)例
$profile = DefaultProfile::getProfile($region, $accessKeyId, $accessKeySecret);
// 增加服務(wù)結(jié)點(diǎn)
DefaultProfile::addEndpoint($endPointName, $region, $product, $domain);
// 初始化AcsClient用于發(fā)起請求
$this->acsClient = new DefaultAcsClient($profile);
}
/**
* 發(fā)送短信范例
* @param [type] $phoneNumbers 必填, 短信接收號(hào)碼
* @param string $signName 必填, 短信簽名,應(yīng)嚴(yán)格"簽名名稱"填寫,
* @param string $templateCode 必填, 短信模板Code,應(yīng)嚴(yán)格按"模板CODE"填寫,
* @param [type] $outId 選填, 假如模板中存在變量需要替換則為必填項(xiàng)
* @return [type] [description]
*/
public function sendSms($phoneNumbers,$signName="XX軟件",$templateCode="SMS_XXXXXX",$outId=null)
{
// 初始化SendSmsRequest實(shí)例用于設(shè)置發(fā)送短信的參數(shù)
$request = new SendSmsRequest;
// 必填,設(shè)置雉短信接收號(hào)碼
$request->setPhoneNumbers($phoneNumbers);
// 必填,設(shè)置簽名名稱
$request->setSignName($signName);
// 必填,設(shè)置模板CODE
$request->setTemplateCode($templateCode);
$num = rand(100000,999999);
// 可選,設(shè)置模板參數(shù)
$request->setTemplateParam(json_encode(
Array(
"code" => "$num"
)
));
// 可選,設(shè)置流水號(hào)
if($outId) {
$request->setOutId($outId);
}
// 發(fā)起訪問請求
$acsResponse = $this->acsClient->getAcsResponse($request);
}
/**
* 查詢短信發(fā)送情況范例
* @param [type] $phoneNumbers 必填, 短信接收號(hào)碼
* @param [type] $sendDate 必填,短信發(fā)送日期,格式Y(jié)md,支持近30天記錄查詢
* @param integer $pageSize 必填,分頁大小
* @param integer $currentPage 必填,當(dāng)前頁碼
* @param [type] $bizId 選填,短信發(fā)送流水號(hào)
* @return [type] [description]
*/
public function queryDetails($phoneNumbers,$sendDate,$pageSize=10,$currentPage=1,$bizId=null)
{
// 初始化QuerySendDetailsRequest實(shí)例用于設(shè)置短信查詢的參數(shù)
$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);
}
}
之后用就實(shí)例化調(diào)用方法就可以了。
總結(jié)
以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,如果有疑問大家可以留言交流,謝謝大家對腳本之家的支持。
您可能感興趣的文章:- Laravel5.2使用Captcha生成驗(yàn)證碼實(shí)現(xiàn)登錄(session巨坑)
- 用Laravel Sms實(shí)現(xiàn)laravel短信驗(yàn)證碼的發(fā)送的實(shí)現(xiàn)
- Laravel下生成驗(yàn)證碼的類
- 使用 laravel sms 構(gòu)建短信驗(yàn)證碼發(fā)送校驗(yàn)功能
- laravel5.4生成驗(yàn)證碼的代碼
- laravel5.4生成驗(yàn)證碼的實(shí)例講解
- Laravel8 使用圖形驗(yàn)證碼做登錄功能的實(shí)現(xiàn)