最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
当前位置: 首页 - 科技 - 知识百科 - 正文

yii2验证码样式如何设置

来源:动视网 责编:小采 时间:2020-11-03 18:18:12
文档

yii2验证码样式如何设置

yii2验证码样式如何设置:yii2验证码样式如何设置第一步,控制器:在任意controller里面重写方法public function actions() { return [ 'captcha' => [ 'class' => 'yii\captcha\CaptchaAction', '
推荐度:
导读yii2验证码样式如何设置:yii2验证码样式如何设置第一步,控制器:在任意controller里面重写方法public function actions() { return [ 'captcha' => [ 'class' => 'yii\captcha\CaptchaAction', '


yii2验证码样式如何设置

第一步,控制器:

在任意controller里面重写方法

public function actions()
{ return [
        'captcha' => [
         'class' => 'yiicaptchaCaptchaAction',
         'fixedVerifyCode' => YII_ENV_TEST ? 'testme' : null,
         'backColor' => 0x000000,//背景颜色
         'maxLength' => 6, //最大显示个数
         'minLength' => 5,//最少显示个数
         'padding' => 5,//间距
         'height' => 40,//高度
         'width' => 130, //宽度
         'foreColor' => 0xffffff, //字体颜色
         'offset' => 4, //设置字符偏移量 有效果
        ],       ]; 
}

第二步,表单模型:

这里只给出验证码相关的部分。

相关文章教程推荐:yii教程

class ContactForm extends Model{ 
 public $verifyCode; 
 public function rules(){ 
 return [
 ['verifyCode', 'required'],
 ['verifyCode', 'captcha'],
 ];
 }
}

验证规则里面验证码的验证器是captcha

第三步,视图:

用ActiveForm生成对应字段。

captchaAction参数指定第一步是在写在哪里的,默认是site里面。

 <?= $form->field($model, 'verifyCode')->widget(Captcha::className(), [
 'template' => '<div class="row"><div class="col-lg-3">{image}</div><div class="col-lg-6">{input}</div></div>',
 ]) ?>

验证码,生成和验证的整个流程就完成了。

以上是生成验证码的流程,因为验证码数字是在代码中写死的,如果我们需要数字的话,那该怎么办呢?

很好办,我们可以自己写个类来继承CaptchaAction,重写generateVerifyCode方法,例子:

namespace yiicaptcha;
class Newcaptcha extends CaptchaAction
{
 protected function generateVerifyCode()
 {
 if ($this->minLength > $this->maxLength) {
 $this->maxLength = $this->minLength;
 }
 if ($this->minLength < 3) {
 $this->minLength = 3;
 }
 if ($this->maxLength > 20) {
 $this->maxLength = 20;
 }
 $length = mt_rand($this->minLength, $this->maxLength);

 $letters = '1234567890123456789012';
 $vowels = 'aeiou';
 $code = '';
 for ($i = 0; $i < $length; ++$i) {
 if ($i % 2 && mt_rand(0, 10) > 2 || !($i % 2) && mt_rand(0, 10) > 9) {
 $code .= $vowels[mt_rand(0, 4)];
 } else {
 $code .= $letters[mt_rand(0, 20)];
 }
 }
 return $code;
 }
}

生成类文件成功。
然后再更改控制器的配置

'captcha' => [
 'class' => 'yiicaptchaNewcaptcha',
 'maxLength' => 5,
 'minLength' =>5
],

好了,更改完成,让我们来看下效果吧!

更多yii框架知识,可以观看相关编程学习课程,!!

文档

yii2验证码样式如何设置

yii2验证码样式如何设置:yii2验证码样式如何设置第一步,控制器:在任意controller里面重写方法public function actions() { return [ 'captcha' => [ 'class' => 'yii\captcha\CaptchaAction', '
推荐度:
标签: 设置 验证码 怎么
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top