效果:
PHP:
<?php
@session_start();
$img = imagecreatetruecolor(100, 30);
$bg_color = imagecolorallocate($img, 255, 255, 255);
imagefill($img, 0, 0, $bg_color);
$count = 4;
$font_content = 'ZXCVBNMASDFGHJKLPOIUYTREWQzxcbnmvfjkdslahsqwertyuiop1234657890';
$font_content_len = strlen($font_content) - 1;
$code_val = '';
for ($i = 0; $i < $count; $i++) {
$font_size = mt_rand(10, 16);
$font_color = imagecolorallocate($img, mt_rand(0, 100), mt_rand(0, 50), mt_rand(0, 255));
$font_c = $font_content[mt_rand(0, $font_content_len)];
$code_val .= $font_c;
$x = ($i * 100 / 4) + rand(10, 15);
$y = mt_rand(5, 15);
imagestring($img, $font_size, $x, $y, $font_c, $font_color);
}
$pix = mt_rand(180, 220);
for ($i = 0; $i < $pix; $i++) {
$point_color = imagecolorallocate($img, mt_rand(0, 255), mt_rand(0, 255), mt_rand(0, 255));
imagesetpixel($img, mt_rand(0, 100), mt_rand(0, 30), $point_color);
}
$line_count = 3;
for ($i = 0; $i < $line_count; $i++) {
$line_color = imagecolorallocate($img, mt_rand(0, 30), mt_rand(0, 30), mt_rand(0, 30));
imageline($img, mt_rand(0, 100), mt_rand(0, 30), mt_rand(0, 100), mt_rand(0, 30), $line_count);
}
header('content-type:image/png', 'j.png');
imagepng($img);
$_SESSION['val_code'] = $code_val;
imagedestroy($img);
HTML:
<?php
@session_start();
//获取验证码
$user_code = isset($_POST['valcode'])?$_POST['valcode']:'';
$val_code =$_SESSION['val_code'];
if(strtolower($user_code) == strtolower($val_code)){
echo '正确';
}else{
echo '请重新如验证码';
}
?>
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Document</title>
</head>
<script>
</script>
<body>
<form method="post" action="form.php">
<p>验证码图片:</p>
<img id="code" src="code.php?rand=<?php echo rand(); ?>" width="100" height="30" alt="">
<p onclick="document.getElementById('code').src='code.php?rand='+Math.random(); ">看不清?</p>
<P>qingshutu:</P>
<input type="text" name="valcode" value="">
<input type="submit" value="提交">
</form>
</body>
</html>