PHP实现验证码

本文介绍了一个基于PHP的验证码系统实现方案,包括了生成四位整数验证码、将验证码存入session、用户验证流程以及生成验证码图片的过程。该系统通过随机生成数字并将其显示在图片上,同时加入了干扰像素来提高安全性。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

数字验证码

 <? 
   
/* 
    *   Filename: authpage.php 
    
*/ 
session_start();
     
//   srand((double)microtime()*1000000); 
        $authnum = $_SESSION['authnum'];
        
//验证用户输入是否和验证码一致 
        if(isset($_POST['authinput']))  
        { 
                
if(strcmp($_POST['authinput'],$_SESSION['authnum'])==0
                        
echo "验证成功!"
                
else 
                        
echo "验证失败!"
        } 
    
        
//生成新的四位整数验证码 

    //    while(($authnum=rand()%10000)<1000);  

    ?> 
        
<form action=test4.php method=post> 
        
<table> 
                请输入验证码:
<input type=text name=authinput style="width: 80px"><br> 
                
<input type=submit name="验证" value="提交验证码"> 
                
<input type=hidden name=authnum value=<? echo $authnum?>> 
                
<img src=authimg.php?authnum=<? echo $authnum?>> 
        
</table> 
        
</form> 

 

 

 authimg.php

<?php 
//生成验证码图片 
Header("Content-type: image/PNG");  
srand((double)microtime()*1000000);//播下一个生成随机数字的种子,以方便下面随机数生成的使用

session_start();//将随机数存入session中
$_SESSION['authnum']="";
$im = imagecreate(62,20); //制定图片背景大小

$black = ImageColorAllocate($im, 0,0,0); //设定三种颜色
$white = ImageColorAllocate($im, 255,255,255); 
$gray = ImageColorAllocate($im, 200,200,200); 

imagefill(
$im,0,0,$gray); //采用区域填充法,设定(0,0)

while(($authnum=rand()%100000)<10000);
//将四位整数验证码绘入图片 
$_SESSION['authnum']=$authnum;
imagestring(
$im, 5, 10, 3, $authnum, $black);
// 用 col 颜色将字符串 s 画到 image 所代表的图像的 x,y 座标处(图像的左上角为 0, 0)。
//如果 font 是 1,2,3,4 或 5,则使用内置字体


for($i=0;$i<200;$i++)    //加入干扰象素 

     
$randcolor = ImageColorallocate($im,rand(0,255),rand(0,255),rand(0,255));
     imagesetpixel(
$im, rand()%70 , rand()%30 , $randcolor); 
}
ImagePNG(
$im); 
ImageDestroy(
$im); 
?>
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值