很久没写了,正好有时间了,把以前想写的先写上。关于yii中的验证码,这里介绍下验证码的使用,好比后台登录的时候输入完用户名和密码后,须要再输入验证码这样会更加的安全。php
从整体来讲 大概分为4个步骤css
1.在对用的控制器里建一个新的控制器方法(actions)web
2.输入验证码的文本框也用小物件安全
3.修改关于验证码的核心类文件(CCapthcaAction) 由于存在一点bugyii
4.而后就是在model里的rules设置规则,判断输入的验证码是否正确了this
接下来就详细说下吧spa
1.我是在后台登录页面里用 因此我就在登录里的controller里开始开发了,下面是生成验证码的方法:code
public function actions(){ return array( 'captcha'=>array( 'class'=>'system.web.widgets.captcha.CCaptchaAction', //引入验证码类,看我写的路径 我想你应该知道这个类在哪里了 'height'=>25, //验证码画布长度 'width'=>80, //验证码画布宽度 'minLength'=>4, //验证码的最小长度 'maxLength'=>4 //验证码的最大长度 ), ); }
2.显示出来component
2种方法 会了第一种 再来第二种 ,在view里写orm
第一种 先把验证码输出:<?php $this->widget('CCaptcha')?>
第二种就是正常的需求了 不只要输出 还要 能够刷新更换了:
<?php
$this->widget('CCaptcha',array('showRefreshButton'=>false,'clickableImage'=>true,'imageOptions'=>array('alt'=>'点击换图','title'=>'点击换图','style'=>'cursor:pointer')));
?>
showRefreshButton的意思是是否显示更换验证码的按钮,意思就是若是这个按钮显示的话 ,每次点击这个按钮,验证码将进行更换
clickableImage 就是点击验证码图片是否进行更换true固然就是赞成了
而后可能你就须要对比下生成的验证码是否相同,在view里能够加个小物件判断
<?php echo $from->error($loginForm,'captcha')?>
三、修改下核心类
找到framework/web/widgets/captcha/CCapthcaAction.php 文件,将run方法进行如上修改,加入一个true 便可。
4.设置规则 ,判断验证码正确与否
到了最后一步 ,来吧 在model里书写验证规则 ,在rules里
array('captcha','captcha','message'=>'验证码错误'),
将本身填写的和 系统生成的对比,若是不一样则提示验证码错误,
而后别忘记显示出来
在 actionindex里
有点懒就截图了 仍是logincontroller里 判断下是否有数据提交 若是有则用attributes进行过滤接受,接收后 判断输入的验证码是否正确便可。
请注意一下这里我改为了this->render() 由于以前方法不能引入系统本身的css和js 因此致使验证码相关类文件没法加载因此改为了如上的render,改为这种,发现前台的头和尾也引入了,怎么办 ,咱们把前台的compoents下的Controller.php文件复制由于到后台的admin模块下的components下的Controller.php,在里面引入一个新的layouts 就好了 这样以前的头和尾 就变成了如今新的头和尾。(若是最后这段看不懂前台后台的话,麻烦看下我博客的 yii讲解的1-4)
而后就大工告成了,验证码能够在页面刷新了