Discuz! X1.5函数分析:submitcheck()
位置:/source/function/function_core.php
作用:
检查提交后的数据,主要是检查验证码、安全提问和来路是不是正常。 string $var 存放在全局变量中的下标 int $allowget 是不是允许get提交 int $seccodecheck 检查验证码 int $secqaacheck 检查安全问答 return返回 boolean
源码:ps.绿色为注释
function submitcheck($var, $allowget = 0, $seccodecheck = 0, $secqaacheck = 0) {
if(!getgpc($var)) {
return FALSE;
} else {
global $_G;
if($allowget || ($_SERVER['REQUEST_METHOD'] == 'POST' && !empty($_G['gp_formhash']) && $_G['gp_formhash'] == formhash() && empty($_SERVER['HTTP_X_FLASH_VERSION']) && (empty($_SERVER['HTTP_REFERER']) ||
preg_replace("/https?:\/\/([^\:\/]+).*/i", "\\1", $_SERVER['HTTP_REFERER']) == preg_replace("/([^\:]+).*/", "\\1", $_SERVER['HTTP_HOST'])))) {
if(checkperm('seccode')) {//return (empty($_G['group'][$perm])?'':$_G['group'][$perm]);会员组权限
//验证问答
if($secqaacheck && !check_secqaa($_G['gp_secanswer'], $_G['gp_sechash'])) {
showmessage('submit_secqaa_invalid');
}
//验证验证码
if($seccodecheck && !check_seccode($_G['gp_seccodeverify'], $_G['gp_sechash'])) {
showmessage('submit_seccode_invalid');//验证码填写错误,请返回修改。
}
}
return TRUE;
} else {
showmessage('submit_invalid');
}
}
}