php通过GD库实现验证码

 


首先看看实现的效果:

具体实现:

<?php
/*PHP实现验证码*/
 
session_start();//开启会话
 
//创建画布
$image=imagecreatetruecolor(100,38);
//背景颜色
$bgcolor=imagecolorallocate($image,255,255,255);
imagefill($image,0,0,$bgcolor);
 
 
$captch_code='';//存储验证码
 
//随机选取4个数字
for($i=0;$i<4;$i++){
    $fontsize=10;        //
    $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);


实现表单的连接和“换一个”功能的实现:

<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <title>Title</title>
</head>
<body>
<form action="">
  <input type="text" placeholder="验证码" name="verifycode" class="captcha"><br><br>
  <img id="captcha_img" src="captcha.php?r=<?php echo rand();?>" alt="验证码" onclick="changeCaptcha(this)">
  <label><a href="" οnclick="alert('hehe')">换一个</a> </label>
</form>
<script>
  function changeCaptcha (val) {
    //点击链接,没有如下弹窗,应该是因为他是a标签的原因
    document.getElementById('captcha_img').src='captcha.php?r='+Math.random();
  }
</script>
</body>
</html>


captcha.php后面加上一个随机参数是为了实现换一个验证码的功能,,换一个功能通过简单的js即可实现。如果没有这个功能可以不用参数。
————————————————
版权声明:本文为CSDN博主「不能吃的坚果」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/C_jian/article/details/52794742

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值