php注册登录时生成的验证码
2016-05-24 15:59
513 查看
http://blog.sina.com.cn/s/blog_8173443e01012l82.html
记得我学php时第一件事就是研究登陆注册。当然,登陆少不了验证码。两年过去了,昨天突然想用个验证码却找不到代码了,现在找到了,贴出来吧。防止我这个马大哈再找不到。随机生成四位数字符串,可以是数字也可以是数字和字母。
authimg.php生成验证码的文件:
<?
$IsLetter = false; //是否出现字母
session_start();
$Num = $_GET["n"];
//生成验证码图片
header("Content-type: image/PNG");
$im = imagecreate(46,20);
srand((double)microtime()*1000000);
$Red = rand(0,200);
$Green = rand(0,200);
$Blue = rand(0,200);
$Color = imagecolorallocate($im, $Red, $Green, $Blue);
$BackGround = imagecolorallocate($im, 255,255,255);
imagefill($im,0,0,$BackGround);
if($IsLetter)
{
$a = substr(md5($Num*10000000000000000),0,1);
$b = substr(md5($Num*10000000000000000),4,1);
$c = substr(md5($Num*10000000000000000),8,1);
$d = substr(md5($Num*10000000000000000),12,1);
}
else
{
$a = substr(hexdec(md5($Num*10000000000000000)),2,1);
$b = substr(hexdec(md5($Num*10000000000000000)),3,1);
$c = substr(hexdec(md5($Num*10000000000000000)),4,1);
$d = substr(hexdec(md5($Num*10000000000000000)),5,1);
}
$Authnum = strtoupper($a.$b.$c.$d);
$_SESSION["Authnum"] = $Authnum;
imagestring($im, 5, 5, 2, $Authnum, $Color);
for($i=0;$i<200;$i++) //加入干扰象素
{
$randcolor = imagecolorallocate($im,rand(0,255),rand(0,255),rand(0,255));
imagesetpixel($im, rand()p , rand()0 , $randcolor);
}
imagepng($im);
imagedestroy($im);
?>
需要显示验证码的文件:
<?
session_start();
$AuthInput = $_POST["AuthInput"];
$action = $_GET["action"];
?>
<script language="javascript">
function lyalert(){
if( addform.AuthInput.value=="") {
alert("请填写验证码");
document.addform.AuthInput.focus();
return false;
}
}
</script>
<form name="addform" method="post" action="?action=save" id="addform" onsubmit="return lyalert()">
<table width="500" border="1" cellpadding="5" cellspacing="0">
<tr><td>验证码:</td>
<td><input name="AuthInput" type="text" id="AuthInput" size="8" maxlength="4" /><script>document.write("<img src=\"authimg.php?n=",Math.random(),"\" />");</script></td></tr>
<tr><td colspan="2" align="center"><input type="submit" name="Button1" value="确定" id="Button1" /></td>
</tr>
</table>
<p> </p>
</form>
<?
if($action=='save')
{
if ($_SESSION["Authnum"] != $AuthInput)
{
?>
<script language="javascript">
alert("验证码输入不正确");
</script>
<?
}
else
{
?>
<script language="javascript">
alert("提交成功!");
</script>
<?
}
}
?>
记得我学php时第一件事就是研究登陆注册。当然,登陆少不了验证码。两年过去了,昨天突然想用个验证码却找不到代码了,现在找到了,贴出来吧。防止我这个马大哈再找不到。随机生成四位数字符串,可以是数字也可以是数字和字母。
authimg.php生成验证码的文件:
<?
$IsLetter = false; //是否出现字母
session_start();
$Num = $_GET["n"];
//生成验证码图片
header("Content-type: image/PNG");
$im = imagecreate(46,20);
srand((double)microtime()*1000000);
$Red = rand(0,200);
$Green = rand(0,200);
$Blue = rand(0,200);
$Color = imagecolorallocate($im, $Red, $Green, $Blue);
$BackGround = imagecolorallocate($im, 255,255,255);
imagefill($im,0,0,$BackGround);
if($IsLetter)
{
$a = substr(md5($Num*10000000000000000),0,1);
$b = substr(md5($Num*10000000000000000),4,1);
$c = substr(md5($Num*10000000000000000),8,1);
$d = substr(md5($Num*10000000000000000),12,1);
}
else
{
$a = substr(hexdec(md5($Num*10000000000000000)),2,1);
$b = substr(hexdec(md5($Num*10000000000000000)),3,1);
$c = substr(hexdec(md5($Num*10000000000000000)),4,1);
$d = substr(hexdec(md5($Num*10000000000000000)),5,1);
}
$Authnum = strtoupper($a.$b.$c.$d);
$_SESSION["Authnum"] = $Authnum;
imagestring($im, 5, 5, 2, $Authnum, $Color);
for($i=0;$i<200;$i++) //加入干扰象素
{
$randcolor = imagecolorallocate($im,rand(0,255),rand(0,255),rand(0,255));
imagesetpixel($im, rand()p , rand()0 , $randcolor);
}
imagepng($im);
imagedestroy($im);
?>
需要显示验证码的文件:
<?
session_start();
$AuthInput = $_POST["AuthInput"];
$action = $_GET["action"];
?>
<script language="javascript">
function lyalert(){
if( addform.AuthInput.value=="") {
alert("请填写验证码");
document.addform.AuthInput.focus();
return false;
}
}
</script>
<form name="addform" method="post" action="?action=save" id="addform" onsubmit="return lyalert()">
<table width="500" border="1" cellpadding="5" cellspacing="0">
<tr><td>验证码:</td>
<td><input name="AuthInput" type="text" id="AuthInput" size="8" maxlength="4" /><script>document.write("<img src=\"authimg.php?n=",Math.random(),"\" />");</script></td></tr>
<tr><td colspan="2" align="center"><input type="submit" name="Button1" value="确定" id="Button1" /></td>
</tr>
</table>
<p> </p>
</form>
<?
if($action=='save')
{
if ($_SESSION["Authnum"] != $AuthInput)
{
?>
<script language="javascript">
alert("验证码输入不正确");
</script>
<?
}
else
{
?>
<script language="javascript">
alert("提交成功!");
</script>
<?
}
}
?>
相关文章推荐
- TP数据查询
- THINKPHP--开发常用
- 基于swoole的Hprose for PHP 开发后端API服务 实践
- TP系统常量信息
- ThinkPHP中Session用法详解
- ThinkPHP部分内置函数
- 用thinkPHP实现验证码的功能
- thinkphp自动验证无效的问题
- ThinkPHP查询数据与CURD
- php基于搜索引擎的资源嗅探器
- 代码实现PHP web服务器下绝对路径到Web网址的转换
- PHP中const的使用
- 设置session的生命周期(php)
- php 导出数据到csv格式
- setcookie各个参数详解
- 系统吞吐量、TPS(QPS)、用户并发详解
- YII自学笔记(四)
- PHP如何开发 MVC框架(一)
- 关于yii的日志路由组件的配置问题
- php实现水仙花