!DOCTYPE html>
html>
head>
title>業(yè)務(wù)A的驗證碼頁面/title>
/head>
body>
img src="" alt="驗證碼" id="imgValCode">
/body>
/html>
script src="jquery.js">/script>
script type="text/javascript">
$.ajax({
url: '/Captcha/A/refresh', //不同業(yè)務(wù)模塊調(diào)用不同的url B業(yè)務(wù)調(diào)用/Captcha/B/refresh
type: 'get',
dataType: 'json',
async: true,
success:function(data) {
if ( data.src ) {
$('#imgValCode').attr('src',data.src);
}
}
});
/script>
?php
/**
* yii1.0 驗證碼類
* 多個驗證碼,方式業(yè)務(wù)A頁面和業(yè)務(wù)B頁面同時打開,共用一個驗證碼session,導(dǎo)致其中一個被失效的問題
*/
class CaptchaController extends CHttpModuleController
{
/**
* 驗證碼生成函數(shù)
*/
public function actions()
{
return [
//A業(yè)務(wù)驗證碼
'A' => [
'class' => 'application.components.MyCaptcha.MyCaptchaAction',
'backColor' => 0xFFFFFF,
'minLength' => 5,
'maxLength' => 5,
'offset' => 5,
'testLimit' => 1,
'width' => 100,
'height' => 40,
'isInterferingLine' => true, //是否啟用干擾線
'interferingLineNumber' => 8, //干擾線數(shù)量設(shè)置
'foreColor' => '0x0c0c0e'
],
//B業(yè)務(wù)驗證碼
'B' => [
'class' => 'application.components.MyCaptcha.MyCaptchaAction',
'backColor' => 0xFFFFFF,
'minLength' => 5,
'maxLength' => 5,
'offset' => 5,
'testLimit' => 1,
'width' => 100,
'height' => 40,
'isInterferingLine' => false, //是否啟用干擾線
'interferingLineNumber' => 8, //干擾線數(shù)量設(shè)置
'foreColor' => '0x0c0c0e'
]
];
}
/**
* 驗證碼驗證函數(shù)
* 在需要驗證驗證碼的控制器中調(diào)用,傳遞businessId(業(yè)務(wù)類型id)作為區(qū)分不同驗證碼的id
* 調(diào)用方式:
* Yii::app()->runController('Captcha/actionVerifyCode',[ 'businessId' => 'A' ]);
*/
public function actionVerifyCode($businessId)
{
$code = Yii::app()->request->getPost('code'); //接收用戶輸入的驗證碼
if ( $businessId == 'A' ) {
$vcode = $this->createAction('A')->getVerifyCode(); //獲取A業(yè)務(wù)的驗證碼
} else if ( $businessId == 'B' ) {
$vcode = $this->createAction('B')->getVerifyCode(); //獲取B業(yè)務(wù)的驗證碼
}
if ( empty($vcode) || empty($code) || $vcode != $code ) { //驗證用戶輸入驗證碼與驗證碼是否相等
return false; //驗證不通過
}
return true; //驗證通過
}
}
?>
到此這篇關(guān)于Yii1.0 不同頁面多個驗證碼的使用實現(xiàn)的文章就介紹到這了,更多相關(guān)Yii1.0 多驗證碼內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!