yzm.php
<?php //开启会话 session_start(); //创建画布 $image=imagecreatetruecolor(100,30); //背景颜色 $bgcolor=imagecolorallocate($image,255,255,255); imagefill($image,10,10,$bgcolor); $captch_code=''; //存储验证码 // //随机选取4个数字 for($i=0;$i<4;$i++){ $fontsize=15; $fontcolor=imagecolorallocate($image,rand(0,120),rand(0,120),rand(0,120));//随机颜色 $fontcontent=rand(0,9); $captch_code.=$fontcontent; $x=($i*100/4)+rand(5,10); //随机坐标 $y=rand(5,10); imagestring($image,$fontsize,$x,$y,$fontcontent,$fontcolor); } //字母和数字混合验证码 // for($i=0;$i<4;$i++) { // $fontsize = 10; // // $fontcolor = imagecolorallocate($image, rand(0, 120), rand(0, 120), rand(0, 120));//?????? // $data = 'abcdefghijklmnopqrstuvwxyz1234567890'; //数据字典 // $fontcontent = substr($data, rand(0, strlen($data)), 1); // $captch_code.=$fontcontent; // $x = ($i * 100 / 4) + rand(5, 10); // $y = rand(5, 10); // imagestring($image, $fontsize, $x, $y, $fontcontent, $fontcolor); // } $_SESSION['code']=$captch_code; //记录下来,便于验证码输入之后对比 //增加干扰点 for($i=0;$i<200;$i++){ $pointcolor=imagecolorallocate($image,rand(50,200),rand(50,200),rand(50,200)); imagesetpixel($image,rand(1,99),rand(1,29),$pointcolor);// } //增加干扰线 for($i=0;$i<3;$i++){ $linecolor=imagecolorallocate($image,rand(80,280),rand(80,220),rand(80,220)); imageline($image,rand(1,99),rand(1,29),rand(1,99),rand(1,29),$linecolor); } //输出格式 header('content-type:image.png'); imagepng($image); //销毁图片 imagedestroy($image);
yzm.html
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
</head>
<body>
<form method="post" action="yzm_ok.php" >
<input type="text" placeholder="用户名" name="username"><br>
<input type="password" placeholder="密码" name="password"><br>
<input type="text" placeholder="验证码" name="yzm" class="captcha"><br>
<img src="yzm.php" onclick="this.src='yzm.php?id='+Math.random()"/>
<button type="submit">登录</button>
</form>
</body>
</html>
yzm_ok.php
<?php session_start();//开启会话 if ( $_POST["yzm"] ==$_SESSION['code']){ echo"验证成功"; } else{ echo"验证失败"; }