您正在使用 IPV4 [34.234.83.135] 访问本站,您本次已经查看了 1 页
用户名: 密 码: 验证码:     用QQ登录本站
首页 软件 编程 笑话 知识 公告 台风 日历 计算器
[公益]保护绿色环境,构建和谐社会       悟空收录网      

【腾讯云】 爆款2核2G3M云服务器首年 61元,叠加红包再享折上折      
[公益] 地球是我家,绿化靠大家      
2024年 清明节 007
2024年 劳动节 034
2025年 元 旦 279
2025年 春 节 307
综合数码金融娱乐服务报刊政府机构 推荐 排名 今日 申请 友情  
您现在的位置:首页 >> PHP >> 内容
本类新增
本类热门
PHP生成带有雪花背景的网站验证码
内容摘要: 以下为引用的内容:?session_start();? FORM METHOD=POST ACTION='' input type=text name=number maxlength=4img src='YanZhengMa.php?act=init' INPUT TYPE='submit' name='sub' /FORM ? //检验校验码 if(is......

以下为引用的内容:

<?session_start();?>

<FORM METHOD=POST ACTION="">

<input type=text name=number maxlength=4><img src="YanZhengMa.php?act=init">

<INPUT TYPE="submit" name="sub">

</FORM>

<?

//检验校验码

if(isset($HTTP_POST_VARS["sub"])):

if($HTTP_POST_VARS["number"] != $HTTP_SESSION_VARS[login_check_number] || empty($HTTP_POST_VARS["number"])){

echo "校验码不正确!" ;

}else{

echo"验证码通过!";

}

endif;

show_source('test.php');

//以上本页的源码

//以下是生成验证码的源码

show_source('YanZhengMa.php');

?>

<?php

session_start();

session_register("login_check_number");

//昨晚看到了chianren上的验证码效果,就考虑了一下,用PHP的GD库完成了类似功能

//先成生背景,再把生成的验证码放上去

$img_height=120; //先定义图片的长、宽

$img_width=40;

if($HTTP_GET_VARS["act"]== "init"){

//srand(microtime() * 100000);//PHP420后,srand不是必须的

for($Tmpa=0;$Tmpa<4;$Tmpa++){

$nmsg.=dechex(rand(0,15));

}

$HTTP_SESSION_VARS[login_check_number] = $nmsg;

//$HTTP_SESSION_VARS[login_check_number] = strval(mt_rand("1111","9999")); //生成4位的随机数,放入session中

//谁能做下补充,可以同时生成字母和数字啊??----由sports98完成了

$aimg = imageCreate($img_height,$img_width); //生成图片

ImageColorAllocate($aimg, 255,255,255); //图片底色,ImageColorAllocate第1次定义颜色PHP就认为是底色了

$black = ImageColorAllocate($aimg, 0,0,0); //定义需要的黑色

ImageRectangle($aimg,0,0,$img_height-1,$img_width-1,$black);//先成一黑色的矩形把图片包围

//下面该生成雪花背景了,其实就是在图片上生成一些符号

for ($i=1; $i<=100; $i++) { //先用100个做测试

imageString($aimg,1,mt_rand(1,$img_height),mt_rand(1,$img_width),"*",imageColorAllocate($aimg,mt_rand(200,255),mt_rand(200,255),mt_rand(200,255)));

//哈,看到了吧,其实也不是雪花,就是生成*号而已。为了使它们看起来"杂乱无章、5颜6色",就得在1个1个生成它们的时候,让它们的位置、颜色,甚至大小都用随机数,rand()或mt_rand都可以完成。

}

//上面生成了背景,现在就该把已经生成的随机数放上来了。道理和上面差不多,随机数1个1个地放,同时让他们的位置、大小、颜色都用成随机数~~

//为了区别于背景,这里的颜色不超过200,上面的不小于200

for ($i=0;$i<strlen($HTTP_SESSION_VARS[login_check_number]);$i++){

imageString($aimg, mt_rand(3,5),$i*$img_height/4+mt_rand(1,10),mt_rand(1,$img_width/2), $HTTP_SESSION_VARS[login_check_number][$i],imageColorAllocate($aimg,mt_rand(0,100),mt_rand(0,150),mt_rand(0,200)));

}

Header("Content-type: image/png"); //告诉浏览器,下面的数据是图片,而不要按文字显示

ImagePng($aimg); //生成png格式。。。嘿嘿效果蛮像回事的嘛。。。

ImageDestroy($aimg);

}

?>

版权声明:本内容来源于网络,如有侵犯您的版权,请联系站长,本站收到您的信息后将及时处理。
上一篇:PHP制作的网站意见在线反馈表

 

下一篇:有效防御PHP木马攻击的技巧

发布日期:2021/6/15
手机扫二维码直达本页
发布时间:12:34:56
点  击:12
录  入:齐天大圣
相关文章
Baidu
YiJiaCMS 7.3.8 build231228(MSSQL) 闽ICP备05000814号-1
本空间由腾讯云(轻量应用服务器)提供,Cloudflare提供加速防护
运行时间载入中.....