澳门新葡8455最新网站:之所以判别验证码是或不是输入有误,来判定投票操作的下边页面

刚装了个DEDECMS英文版本的,坑爹评论用不了,一直都显示验证错误,坑死@。

一、判断上一级页面

因为正确的验证码结果已经经过加密之后保存在了session中,所有用于输入的验证码会跟session中的进行比对,从而判断验证码是否输入有误!

验证码生成程序我这里就不介绍了,大家可参考
下面介绍一个简单的

后台验证码确信是对的,但是一直提示验证码错误。引起错误原因:恢复数据库(刚恢复后,后台的基本设置的数据都是数据库的,但是页面不显示。当点击保存后,页面上就显示出来了,但是同时,后台登录就会提示验证码错误。)

通过http请求header中的refere,来判断投票操作的上级页面,可以防止直接发送请求来进行投票的部分自动投票软件。

既然老是显示:”验证码输入有误”

 代码如下

解决方法:

/**
* 判断上一级页面
*/
if(!strpos($_SERVER[‘HTTP_REFERER’],’
$this->ajaxReturn(“请从投票页面进入投票!”);
}

说明session中保存到结果可能有问题。然后,dump下session,发现结果为null……

<?php 
session_start();
//设置: 你可以在这里修改验证码图片的参数
$image_width = 120;
$image_height = 40;
$characters_on_image = 6;
$font = ‘./monofont.ttf’; 
 
//以下字符将用于验证码中的字符 
//为了避免混淆去掉了数字1和字母i
$possible_letters = ‘23456789bcdfghjkmnpqrstvwxyz’;
$random_dots = 10;
$random_lines = 30;
$captcha_text_color=”0x142864″;
$captcha_noice_color = “0x142864”; 
 
$code = ”; 
 
$i = 0;
while ($i < $characters_on_image) { 
    $code .=
substr($possible_letters,
mt_rand(0, strlen($possible_letters)-1), 1);
    $i++;
}
 
$font_size = $image_height * 0.75; 
$image = @imagecreate($image_width, $image_height);
 
/* 设置背景、文本和干扰的噪点 */
$background_color = imagecolorallocate($image, 255, 255, 255);
 
$arr_text_color = hexrgb($captcha_text_color); 
$text_color = imagecolorallocate($image, $arr_text_color[‘red’], 
$arr_text_color[‘green’], $arr_text_color[‘blue’]);
 
$arr_noice_color = hexrgb($captcha_noice_color); 
$image_noise_color = imagecolorallocate($image,
$arr_noice_color[‘red’], 
$arr_noice_color[‘green’], $arr_noice_color[‘blue’]);
 
/* 在背景上随机的生成干扰噪点 */
for( $i=0; $i<$random_dots; $i++ ) {
    imagefilledellipse($image,
mt_rand(0,$image_width),
    mt_rand(0,$image_height), 2, 3, $image_noise_color);
}
 
/* 在背景图片上,随机生成线条 */
for( $i=0; $i<$random_lines; $i++ ) {
    imageline($image, mt_rand(0,$image_width),
mt_rand(0,$image_height),
    mt_rand(0,$image_width), mt_rand(0,$image_height),
$image_noise_color);
}
 
/* 生成一个文本框,然后在里面写生6个字符 */
$textbox = imagettfbbox($font_size, 0, $font, $code); 
$x = ($image_width – $textbox[4])/2;
$y = ($image_height – $textbox[5])/2;
imagettftext($image, $font_size, 0, $x, $y, $text_color, $font ,
$code);
 
/* 将验证码图片在HTML页面上显示出来 */
header(‘Content-Type: image/jpeg’);
// 设定图片输出的类型
imagejpeg($image);
//显示图片
imagedestroy($image);
//销毁图片实例
$_SESSION[‘6_letters_code’] = $code;
 
function hexrgb ($hexstr) {
    $int = hexdec($hexstr);
 
    return array( “red” => 0xFF & ($int >> 0x10),
                “green” => 0xFF & ($int >> 0x8),
                “blue” => 0xFF & $int
    );
}
?>

打开include/common.func.php文件找到GetCkVdValue函数中return
isset($_SESSION[‘securimage_code_value’]) ?
$_SESSION[‘securimage_code_value’] : ”;修改为:return
isset($_SESSION[‘securimage_code_value’]) ?
trim($_SESSION[‘securimage_code_value’]) : ”;

二、判断是否在微信上操作

解决办法:

验证码

希望能帮到大家,如果有问题可以直接在下面留言,第一时间问你解决。

通过请求头部信息中的agent来判断打开的客户端。

使用phpinfo查看session信息,找出session的保存路径,然后给其设置写入的权限即可

生成后,我们要在实际的项目中应用,通常我们使用ajax可以实现点击验证码时刷新生成新的验证码(有时生成的验证码肉眼很难识别),即“看不清换一张”。填写验证码后,还需要验证所填验证码是否正确,验证的过程是要后台程序来完成,但是我们也可以通过ajax来实现无刷新验证。

/**
* 判断客户端信息
*/
if(!strpos($_SERVER[‘HTTP_USER_AGENT’],’MicroMessenger’)){
$this->ajaxReturn(“请在微信上进行投票!”);
}

如果无法解决可以参考下面

验证验证码正确或错误的方法
验证码图片上的文字被存放到了SESSION
变量里面,验证的时候,我们需要将SESSION
里面的值和用户输入的值进行比较即可。

三、验证码

现在我们来抛开cookie使用session,主要途径有三条:

$_SESSION[6_letters_code] – 存放着验证码的文字值
$_POST[6_letters_code] – 这是用户输入的验证码的内容

相关文章

You can leave a response, or trackback from your own site.

Leave a Reply

网站地图xml地图