herrsammyde / recaptcha
此包已被弃用且不再维护。未建议替代包。
为 Laravel 5 的 reCAPTCHA 验证器
2.2.3
2022-01-16 03:54 UTC
Requires
- php: >=5.3.0
- illuminate/support: ~5.1|^6.0|^7.0|^8.0
README
所有美好的事物都必将走到尽头。遗憾的是,我没有时间维护这个包,因此 Laravel 6 的发布就像是一个完美的分手。你应该看看分支,看看是否有人继续传承。
感谢大家多年来一直支持这个包!
Recaptcha
为 Laravel 5 的 reCAPTCHA 验证器。
(寻找 Laravel 4 版本?拉取最新的 1.x 标签。对于 Laravel 5.0,拉取最新的 2.0 标签。)
安装
将以下行添加到 composer.json
中的 require
部分
{ "require": { "greggilbert/recaptcha": "dev-master" } }
设置
- 在
/config/app.php
中,将以下内容添加到providers
Greggilbert\Recaptcha\RecaptchaServiceProvider::class,
并添加以下内容到 aliases
'Recaptcha' => Greggilbert\Recaptcha\Facades\Recaptcha::class,
- 运行
php artisan vendor:publish --provider="Greggilbert\Recaptcha\RecaptchaServiceProvider"
。 - 在
/config/recaptcha.php
中,输入您的 reCAPTCHA 公钥和私钥。
- 如果您不是使用最新版本的 reCAPTCHA,请将
version
设置为 1。 - 如果您要升级到 reCAPTCHA 的 v2 版本,请注意,您之前版本的密钥将无法使用,您需要在 reCAPTCHA 管理员中生成一组新的密钥。
- 该包附带默认验证消息,但如果你想自定义它,请将以下行添加到
resources/lang/[lang]/validation.php
'recaptcha' => 'The :attribute field is not correct.',
使用
v2 (无验证码)
- 在你的表单中,使用
{!! Recaptcha::render() !!}
输出标记。 - 在你的验证规则中添加以下内容
$rules = [ // ... 'g-recaptcha-response' => 'required|recaptcha', ];
v1 (传统)
- 在你的表单中,使用
{!! Recaptcha::render() !!}
输出标记。 - 在你的验证规则中添加以下内容
$rules = [ // ... 'recaptcha_response_field' => 'required|recaptcha', ];
建议在验证时添加 required
。
自定义
reCAPTCHA v2 允许通过多个选项自定义小部件,这些选项在官方文档中列出。您可以通过六个允许的键配置 captcha 的输出:theme
、type
、lang
、callback
、tabindex
和 expired-callback
。
在配置文件中,您可以创建一个 options
数组来设置默认行为。例如
// ... 'options' => [ 'lang' => 'ja', ],
将所有 reCAPTCHAs 的默认语言设置为日语。如果您想进一步自定义,您可以通过 render 选项传递选项
echo Recaptcha::render([ 'lang' => 'fr' ]);
传递给 Recaptcha::render
的选项将始终覆盖配置。
语言
要更改 captcha 的语言,只需将语言作为选项的一部分传递即可
'options' => [ 'lang' => 'fr', ],
有关有效语言代码的列表,请参阅官方文档。
自定义模板
或者,如果您想设置默认模板而不是标准模板,您可以使用配置
// ... 'template' => 'customCaptcha',
或者您也可以通过表单选项传递它
echo Recaptcha::render([ 'template' => 'customCaptcha' ]);
v1 自定义化
有关 v1 自定义化选项,请参考旧版文档并相应应用。
限制
由于 Google 显示 reCAPTCHA 的方式,如果您通过 AJAX 调用加载表单,此包将无法正常工作。如果您需要这样做,您应该使用 Google 提供的备用方法之一。