yii2框架的Js验证码,所有的使用方式跟系统自带的yii\captcha\Captcha一致。
本代码主要使用极验的服务,并进行yii2封装,使得所有的代码开放极为简单!感谢极验团队提供的免费服务,同时也欢迎购买其付费服务!
推荐的方式是通过composer 进行下载安装composer。
添加入如下两行:
"ethercap/yii2-captcha" : "@dev",
"gee-team/gt3-php-sdk": "@dev",
到你的composer.json
文件中的require段。
如下为极验js验证码的示例,我们将以登录为例来讲解如何使用该插件:
- 在配置文件中(如common/config/main.php)加入如下的代码:
return [
'components' => [
'geetest' => [
'class' => 'ethercap\captcha\Geetest',
'gtId' => '极验的ID'
'gtKey' => '极验的Key',
],
],
]
];
- 在LoginForm中加入captcha的rules, LoginForm的示例可能如下:
class LoginForm extends Model
{
public $phone;
public $smsCaptcha;
public $captcha;
public $rememberMe = true;
// ...其它代码
public rules()
{
return [
// 该规则类似于\yii\captcha\CaptchaValidator,会将post过来的数据自动去极验后台校验
['captcha', '\ethercap\captcha\GtCaptchaValidator'],
// ...其它规则
],
}
public function login()
{
//具体登录代码...
}
public function sendSms()
{
//具体发送验证码代码...
}
}
3.在前端页面(如login.php)上加上captcha的展示:
<?= GtCaptcha::widget([
'onSuccess' => 'function(result){
sendSms(); // js验证码成功时的动作,本例中为js发出短信验证码
}',
'type' => GtCaptcha::TYPE_BIND, //type为绑定,意思为当点击id为bindTo配置(即sendsms)时,调出极验验证框
'bindTo' => 'sendsms',
'name' => 'LoginForm[captcha]', // input的name
'gtOptions' => [ //gt的显示option
'width' => '50%',
],
]);?>
如上即为示例中的widget的展示,更多配置请参照本文中下面的配置章节
4.书写相应的controller,该内容跟本包无关,但是需要调用相应LoginForm的validate()方法。
经过如上的配置后,你会发现,当你点击按钮时,会直接掉起js校验,后端和前端的校验均已经OK!
本代码仓库对极验的前端控件进行了完美的封装,详情请参考极验官方文档及本封装代码说明。
我们是一群热爱技术,追求卓越的极客,我们乐于做一些对整个社会都有作用的事情,我们希望通过我们的努力来推动整个社会的创新,如果你也一样,欢迎加入我们([email protected])!你也可以通过https://tech.ethercap.com 来了解更多!