本文實(shí)例講述了YII2框架中驗(yàn)證碼的簡(jiǎn)單使用方法。分享給大家供大家參考,具體如下:
驗(yàn)證碼的使用是比較頻繁的。YII2中已經(jīng)幫我們做好了封裝。
首先我們?cè)诳刂破骼飫?chuàng)建一個(gè)actions方法,用于使用yii\captcha\CaptchaAction
?php
namespace app\controllers;
use YII;
use yii\web\Controller;
class IndexController extends Controller
{
public function actionIndex()
{
if (YII::$app->request->isPost) {
//獲取post過(guò)來(lái)的驗(yàn)證碼
$verify = YII::$app->request->post('verify');
//我們手動(dòng)進(jìn)行驗(yàn)證,第二個(gè)參數(shù)表示是否區(qū)分大小寫(xiě)
if ($this->createAction('captcha')->validate($verify, false)) {
echo '成功';
} else {
echo '失敗';
}
} else {
return $this->renderPartial('index');
}
}
//actions的作用主要是共用功能相同的方法
//當(dāng)用戶訪問(wèn)index/captcha時(shí),actions就會(huì)調(diào)用yii\captcha\CaptchaAction方法
public function actions()
{
return [
'captcha' => [
'class' => 'yii\captcha\CaptchaAction',
'fixedVerifyCode' => null,
//背景顏色
'backColor' => 0x000000,
//最大顯示個(gè)數(shù)
'maxLength' => 4,
//最少顯示個(gè)數(shù)
'minLength' => 4,
//間距
'padding' => 2,
//高度
'height' => 30,
//寬度
'width' => 85,
//字體顏色
'foreColor' => 0xffffff,
//設(shè)置字符偏移量
'offset' => 4,
],
];
}
}
顯示頁(yè)面代碼如下:
?php
use yii\helpers\Url;
use yii\helpers\Html;
?>
!doctype html>
html lang="zh-CN">
head>
meta charset="UTF-8">
title>分頁(yè)顯示/title>
/head>
body>
form action="?php echo Url::toRoute('index/index'); ?>" method="post">
驗(yàn)證碼:input type="text" name="verify">br>
img id="verifyImg" src="?php echo Url::toRoute('index/captcha'); ?>">br>
input type="submit" value="提交">
input name="_csrf" type="hidden" value="?php echo \Yii::$app->request->csrfToken; ?>">
/form>
?php echo Html::jsFile('@web/js/jquery-3.3.1.min.js'); ?>
script type="text/javascript">
$(function () {
//處理點(diǎn)擊刷新驗(yàn)證碼
$("#verifyImg").on("click", function () {
$.get("?php echo Url::toRoute('index/captcha') ?>?refresh", function (data) {
$("#verifyImg").attr("src", data["url"]);
}, "json");
});
});
/script>
/body>
/html>
演示結(jié)果如下:
![](/d/20211017/2376f5f27e08522975401f7299be0594.gif)
上面控制器中驗(yàn)證碼的驗(yàn)證方式是我們手動(dòng)的。我們也可以創(chuàng)建一個(gè)模型配置rules()來(lái)自動(dòng)完成。
?php
namespace app\models;
use yii\base\Model;
class VerifyForm extends Model
{
//變量名為你表單中輸入驗(yàn)證碼控件的name
public $verify;
public function rules()
{
return [
['verify', 'required', 'message' => '請(qǐng)?zhí)顚?xiě)驗(yàn)證碼'],
//注意captchaAction的設(shè)置,指向你顯示驗(yàn)證碼的action,這里我們的是index/captcha
['verify', 'captcha', 'captchaAction' => 'index/captcha', 'caseSensitive' => false, 'message' => '驗(yàn)證碼錯(cuò)誤'],
];
}
}
控制器代碼修改如下:
?php
namespace app\controllers;
use YII;
use app\models\VerifyForm;
use yii\web\Controller;
class IndexController extends Controller
{
public function actionIndex()
{
if (YII::$app->request->isPost) {
$verify = new VerifyForm();
$verify->load(YII::$app->request->post(), '');
//自動(dòng)驗(yàn)證
if ($verify->validate()) {
echo '成功';
} else {
var_dump($verify->errors);
}
} else {
return $this->renderPartial('index');
}
}
//actions的作用主要是共用功能相同的方法
//當(dāng)用戶訪問(wèn)index/captcha時(shí),actions就會(huì)調(diào)用yii\captcha\CaptchaAction方法
public function actions()
{
return [
'captcha' => [
'class' => 'yii\captcha\CaptchaAction',
'fixedVerifyCode' => null,
//背景顏色
'backColor' => 0x000000,
//最大顯示個(gè)數(shù)
'maxLength' => 4,
//最少顯示個(gè)數(shù)
'minLength' => 4,
//間距
'padding' => 2,
//高度
'height' => 30,
//寬度
'width' => 85,
//字體顏色
'foreColor' => 0xffffff,
//設(shè)置字符偏移量
'offset' => 4,
],
];
}
}
更多關(guān)于Yii相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《Yii框架入門及常用技巧總結(jié)》、《php優(yōu)秀開(kāi)發(fā)框架總結(jié)》、《smarty模板入門基礎(chǔ)教程》、《php面向?qū)ο蟪绦蛟O(shè)計(jì)入門教程》、《php字符串(string)用法總結(jié)》、《php+mysql數(shù)據(jù)庫(kù)操作入門教程》及《php常見(jiàn)數(shù)據(jù)庫(kù)操作技巧匯總》
希望本文所述對(duì)大家基于Yii框架的PHP程序設(shè)計(jì)有所幫助。
您可能感興趣的文章:- yii2.0框架使用 beforeAction 防非法登陸的方法分析
- Yii2使用$this->context獲取當(dāng)前的Module、Controller(控制器)、Action等
- Yii框架獲取當(dāng)前controlle和action對(duì)應(yīng)id的方法
- yii框架配置默認(rèn)controller和action示例
- YII2框架中分頁(yè)組件的使用方法示例
- YII2框架中自定義用戶認(rèn)證模型,完成登陸和注冊(cè)操作示例
- YII2框架實(shí)現(xiàn)表單中上傳單個(gè)文件的方法示例
- YII2框架中操作數(shù)據(jù)庫(kù)的方式實(shí)例分析
- YII2框架自定義全局函數(shù)的實(shí)現(xiàn)方法小結(jié)
- yii2.0框架場(chǎng)景的簡(jiǎn)單使用示例
- YII2框架中actions的作用與使用方法示例