首先安装 mews/captcha 扩展包并发布配置文件以自定义验证码样式,接着在路由或控制器中生成验证码图像,通过 Blade 模板展示并支持点击刷新,最后在表单验证时使用 captcha 规则校验用户输入,同时可自定义错误提示信息,确保 PHP 已启用 GD 和 FreeType 扩展以支持图片生成。

在 Laravel 中实现验证码(Captcha)功能,通常用于防止机器人自动提交表单,比如登录、注册或评论。最常见的方式是使用第三方扩展包 mews/captcha,它基于 GD 库生成图形验证码,集成简单且稳定。
在项目根目录运行以下命令安装 mews/captcha:
composer require mews/captcha如果你使用的是 Laravel 5.5 ~ 8.x 版本,服务提供者和门面会自动注册。Laravel 9 及以上版本建议检查是否需要手动注册。
虽然默认配置可用,但你可以发布配置文件进行自定义:
php artisan vendor:publish --provider="Mews\Captcha\CaptchaServiceProvider"这会在 config/captcha.php 生成配置文件,你可以修改验证码的长度、字体、背景颜色、扭曲程度等参数。
在路由或控制器中生成验证码图像。例如,在路由中直接输出:
Route::get('captcha', function () { return captcha(); });或者在控制器中:
class AuthController extends Controller { public function getCaptcha() { return response(captcha()->create('default', true))->header('Content-Type', 'image/png'); } }也可以在 Blade 模板中使用 captcha_img() 直接显示:
点击刷新验证码通过添加随机参数防止缓存。
在表单提交时,使用验证规则 captcha 来校验输入:
$request->validate([ 'email' => 'required|email', 'password' => 'required', 'captcha' => 'required|captcha' ]);如果用户输入的验证码不正确,会自动返回错误信息。你也可以手动检查:
if (!captcha_check($request->input('captcha'))) { return back()->withErrors(['captcha' => '验证码错误']); }在 resources/lang/zh_CN/validation.php(或其他语言文件)中添加:
'captcha' => '验证码不正确。',这样可以统一提示语。
基本上就这些。使用 mews/captcha 能快速集成图形验证码,适合大多数 Laravel 项目。注意确保 PHP 开启了 GD 扩展和 FreeType 支持,否则无法生成图片。
以上就是Laravel怎么实现验证码(Captcha)功能的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号