加入收藏 | 设为首页 | 会员中心 | 我要投稿 常州站长网 (https://www.0519zz.com/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 综合聚焦 > 编程要点 > 语言 > 正文

YII2框架如何生成验证码

发布时间:2022-04-14 13:52:38 所属栏目:语言 来源:互联网
导读:如何使用yii2生成验证码?验证码的使用可以说是很频繁的了,我们在做账号登陆的时候,经常需要做验证码验证,那么我们具体要如何做一个验证码呢?YII2中已经帮我们做好了封装,下面我们就来看看YII2框架中验证码的使用方法。 验证码的使用是比较频繁的。YII2
      如何使用yii2生成验证码?验证码的使用可以说是很频繁的了,我们在做账号登陆的时候,经常需要做验证码验证,那么我们具体要如何做一个验证码呢?YII2中已经帮我们做好了封装,下面我们就来看看YII2框架中验证码的使用方法。
 
       验证码的使用是比较频繁的。YII2中已经帮我们做好了封装。
 
       首先我们在控制器里创建一个actions方法,用于使用yiicaptchaCaptchaAction
 
<?php
 
namespace appcontrollers;
 
use YII;
use yiiwebController;
 
class IndexController extends Controller
{
  public function actionIndex()
  {
    if (YII::$app->request->isPost) {
      //获取post过来的验证码
      $verify = YII::$app->request->post('verify');
 
      //我们手动进行验证,第二个参数表示是否区分大小写
      if ($this->createAction('captcha')->validate($verify, false)) {
        echo '成功';
      } else {
        echo '失败';
      }
 
    } else {
      return $this->renderPartial('index');
    }
  }
 
  //actions的作用主要是共用功能相同的方法
  //当用户访问index/captcha时,actions就会调用yiicaptchaCaptchaAction方法
  public function actions()
  {
    return [
      'captcha' => [
        'class' => 'yiicaptchaCaptchaAction',
        'fixedVerifyCode' => null,
        //背景颜色
        'backColor' => 0x000000,
        //最大显示个数
        'maxLength' => 4,
        //最少显示个数
        'minLength' => 4,
        //间距
        'padding' => 2,
        //高度
        'height' => 30,
        //宽度
        'width' => 85,
        //字体颜色
        'foreColor' => 0xffffff,
        //设置字符偏移量
        'offset' => 4,
 
  <?php echo Html::jsFile('@web/js/jquery-3.3.1.min.js'); ?>
  <script type="text/javascript">
    $(function () {
      //处理点击刷新验证码
      $("#verifyImg").on("click", function () {
        $.get("<?php echo Url::toRoute('index/captcha') ?>?refresh", function (data) {
          $("#verifyImg").attr("src", data["url"]);
        }, "json");
      });
    });
  </script>
</body>
</html> 

(编辑:常州站长网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    热点阅读