当前位置: 首页 > news >正文

Laravel 12 实现验证码功能

Laravel 12 实现验证码功能

在 Laravel 12 中实现验证码功能可以通过多种方式,以下是几种常见的方法:

方法一:使用 Captcha 包(推荐)

  1. 首先安装 mews/captcha 包:
composer require mews/captcha
  1. 发布配置文件:
php artisan vendor:publish --provider="Mews\Captcha\CaptchaServiceProvider"
  1. config/captcha.php 中配置验证码选项

  2. 在表单视图中添加验证码:

<div class="form-group"><label for="captcha">验证码</label>{!! captcha_img() !!}<input id="captcha" type="text" class="form-control" name="captcha" required>
</div>
  1. 在控制器中验证:
public function postRegister(Request $request)
{$this->validate($request, ['captcha' => 'required|captcha']);// 其他注册逻辑
}

方法二:使用 Google reCAPTCHA

  1. 安装 Google reCAPTCHA 包:
composer require google/recaptcha
  1. .env 中添加:
RECAPTCHA_SITE_KEY=your_site_key
RECAPTCHA_SECRET_KEY=your_secret_key
  1. 在表单中添加:
<div class="g-recaptcha" data-sitekey="{{ env('RECAPTCHA_SITE_KEY') }}"></div>
<script src="https://www.google.com/recaptcha/api.js"></script>
  1. 在控制器中验证:
use ReCaptcha\ReCaptcha;public function validateCaptcha(Request $request)
{$recaptcha = new ReCaptcha(env('RECAPTCHA_SECRET_KEY'));$response = $recaptcha->verify($request->input('g-recaptcha-response'), $request->ip());if (!$response->isSuccess()) {// 验证失败处理}// 其他逻辑
}

方法三:自定义验证码(简单实现)

  1. 创建验证码生成路由:
Route::get('/captcha', function() {$image = imagecreatetruecolor(100, 40);$bgColor = imagecolorallocate($image, 255, 255, 255);$textColor = imagecolorallocate($image, 0, 0, 0);imagefilledrectangle($image, 0, 0, 100, 40, $bgColor);$code = substr(str_shuffle('0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ'), 0, 6);session(['captcha' => $code]);imagestring($image, 5, 20, 12, $code, $textColor);header('Content-Type: image/png');imagepng($image);imagedestroy($image);
});
  1. 在视图中使用:
<img src="/captcha" alt="CAPTCHA" onclick="this.src='/captcha?'+Math.random()">
<input type="text" name="captcha" required>
  1. 验证:
if ($request->input('captcha') !== session('captcha')) {return back()->withErrors(['captcha' => '验证码错误']);
}

注意事项

  1. 验证码应该有一定的复杂度,防止被机器识别
  2. 可以考虑添加干扰线、噪点等增加安全性
  3. 验证码应该有有效期限制(通常5-10分钟)
  4. 对于重要操作,建议使用更安全的验证方式如短信验证码

以上方法可以根据项目需求选择使用,第一种方法是最简单快捷的实现方式。

http://www.xdnf.cn/news/321571.html

相关文章:

  • 代码随想录算法训练营第三十四天
  • WordPress个人博客搭建(三):WordPress网站优化
  • RabbitMq学习(第一天)
  • 5.7 react 路由
  • Go语言八股之并发详解
  • 管家婆实用贴-如何在Excel中清除空格
  • Go语言——error、panic
  • 解决0x0000011b共享打印机无法连接!
  • 泛型设计模式实践
  • 初始图形学(7)
  • 2025-05-07-FFmpeg视频裁剪(尺寸调整,画面比例不变)
  • 系统思考:教育焦虑恶性循环分析
  • C语言初阶:数组
  • DeepSeek全域智能革命:从量子纠缠到星际文明的认知跃迁引言:认知边界的坍缩与重构
  • 解决leetcode第3537题填充特殊网格
  • CSS详细学习笔记
  • eclipse常用快捷键
  • Jmeter进行http接口测试
  • 使用VSCode在Windows 11上编译运行项目
  • 005 权限的理解
  • Linux上将conda环境VLLM服务注册为开机自启
  • Java 常用的 ORM框架(对象关系映射)
  • 企业级AI革命!私有化部署开源大模型:数据安全+自主可控,打造专属智能引擎
  • Ubuntu20.04安装使用ROS-PlotJuggler
  • 【MCP】客户端配置(ollama安装、qwen2.5:0.5b模型安装、cherry-studio安装配置)
  • C#与Halcon联合编程
  • 迁移学习:如何加速模型训练和提高性能
  • 锁相环HMC830的调试
  • 缓存替换算法与存储器管理的分页、分段、段页式管理联系
  • http Status 400 - Bbad request 网站网页经常报 HTTP 400 错误,清缓存后就好了的原因