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. $name 指短信签名 可以在阿里大鱼短信签名 http://www.alidayu.com/admin/service/sign 找到
  3. $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);


		}


	}


之后用就实例化调用方法就可以了。
 
 
 
 
 
  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Laravel 实现验证码功能可以通过以下步骤来完成: 1. 首先,你需要安装一个验证码库,比如 popular-captcha 或 Socialite。你可以使用 Composer 运行以下命令来安装所需的库: ``` composer require mews/captcha ``` 2. 在 Laravel ,你可以使用 Laravel 自带的 Validator 类或 captcha() 函数来对验证码进行验证。Validator 类提供了一个简单的方法来验证用户输入的验证码是否正确。你可以在控制器的验证方法添加以下代码来进行验证码验证: ```php use Illuminate\Support\Facades\Validator; public function validateCaptcha(Request $request) { $validator = Validator::make($request->all(), [ 'captcha' => 'required|captcha', ]); if ($validator->fails()) { // 验证码验证失败处理 } else { // 验证码验证成功处理 } } ``` 3. 当用户输入错误的验证码时,你可以使用 Laravel 自带的 Validation Exception 来处理验证码错误。你可以在控制器方法使用 try-catch 块来捕获验证码验证的异常,并在异常处理程序给出相应的提示信息: ```php use Illuminate\Validation\ValidationException; public function validateCaptcha(Request $request) { try { $validator = Validator::make($request->all(), [ 'captcha' => 'required|captcha', ]); if ($validator->fails()) { throw ValidationException::withMessages([ 'captcha' => '验证码错误', ]); } // 验证码验证成功处理 } catch (ValidationException $e) { // 验证码验证失败处理 return redirect()->back()->withErrors($e->errors()); } } ``` 通过以上步骤,你可以在 Laravel 实现验证码功能。你可以根据你的具体需求来定制验证码的生成和验证逻辑,并在验证失败时给出适当的提示信息。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值