最近在做PHP项目,发现验证码是必须在登陆页面出现的,如图所示:
研究了一下实现方法,发现是使用code.php生成验证码,并且把生成的验证码存入session会话,具体验证码代码如下:
<?php
//此文件存为code.php放到php根目录
session_start();
$img = imagecreatetruecolor(100, 35);
$black = imagecolorallocate($img, 0x00, 0x00, 0x00);
$green = imagecolorallocate($img, 0x00, 0xFF, 0x00);
$white = imagecolorallocate($img, 0xFF, 0xFF, 0xFF);
imagefill($img,0,0,$white);
//生成随机的验证码
$code = '';
for($i = 0; $i < 4; $i++) {
$code .= rand(0, 9);
}
$_SESSION['Checknum'] = $code;
//$_SESSION['Checknum'] = $code; 为存储验证码到session会话,其他页面判断此值即可判断验证码
imagestring($img, 30, 28, 10, $code, $black);
//加入噪点干扰
for($i=0;$i<200;$i++) {
imagesetpixel($img, rand(0, 100) , rand(0, 100) , $black);
imagesetpixel($img, rand(0, 100) , rand(0, 100) , $green);
}
//输出验证码
header("content-type: image/png");
imagepng($img);
imagedestroy($img);
?>
//此文件存为code.php放到php根目录
session_start();
$img = imagecreatetruecolor(100, 35);
$black = imagecolorallocate($img, 0x00, 0x00, 0x00);
$green = imagecolorallocate($img, 0x00, 0xFF, 0x00);
$white = imagecolorallocate($img, 0xFF, 0xFF, 0xFF);
imagefill($img,0,0,$white);
//生成随机的验证码
$code = '';
for($i = 0; $i < 4; $i++) {
$code .= rand(0, 9);
}
$_SESSION['Checknum'] = $code;
//$_SESSION['Checknum'] = $code; 为存储验证码到session会话,其他页面判断此值即可判断验证码
imagestring($img, 30, 28, 10, $code, $black);
//加入噪点干扰
for($i=0;$i<200;$i++) {
imagesetpixel($img, rand(0, 100) , rand(0, 100) , $black);
imagesetpixel($img, rand(0, 100) , rand(0, 100) , $green);
}
//输出验证码
header("content-type: image/png");
imagepng($img);
imagedestroy($img);
?>
登陆页面在form表单中调入当前code.php文件到合适地方
<input name="passcode" type="text" />
<img src="code.php" />
<img src="code.php" />
注意一个重要的地方:
操作之前必须打开php的GD库,修改php.ini文件的配置,取消extension=php_gd2.dll前面的分号。
之后刷新页面即可出线验证码在登陆界面。
但是如何对验证码进行判断呢?
看我的代码:
<?php
session_start();
$code = isset($_REQUEST['passcode'])? $_REQUEST['passcode'] : '';
if($code) {
if( $code == $_SESSION["Checknum"]){
//这里接数据库判断登陆即可
}
else {
echo '<script>alert("验证码输入错误!");window.location.href="login.php";</script>';
}
?>
session_start();
$code = isset($_REQUEST['passcode'])? $_REQUEST['passcode'] : '';
if($code) {
if( $code == $_SESSION["Checknum"]){
//这里接数据库判断登陆即可
}
else {
echo '<script>alert("验证码输入错误!");window.location.href="login.php";</script>';
}
?>
我是在当前页面处理form表单传递的值,所以直接使用if($code) 判断值即是否为空对验证码进行判断即可。
希望对验证码研究需求的同学有帮助。