使用PHP实现登陆验证码

使用PHP实现登陆验证码

原理:生成一个图片,并且保存图片中显示的字符到SESSION.在登陆时判断输入的校验码是否和SESSION中校验码相同.
这是生成校验码和图片的文件checkNumber.php

[复制到剪切板]
CODE:
<?php
session_start
();

if(
$act == "init")
{
    
Header("Content-type: image/png");
    
srand(microtime() * 100000);
    
$login_check_number strval(rand("1111","9999"));

    
session_register("login_check_number");
    
//这里是使用了SESSION来保存校验码.
    //当然也可以用COOKIE
    //setcookie("login_check_number",$login_check_number);
    //然后将第一行的session_start()删除;
    //不推荐使用COOKIE,因为使用COOKIE并不能进行安全的验证.

    
$h_img imagecreate(40,17);
    
$c_black ImageColorAllocate($h_img0,0,0);
    
$c_white ImageColorAllocate($h_img255,255,255);
    
imageline($h_img1135025$c_black);
    
imagearc($h_img20015202035190$c_white);
    
imagestring($h_img521$login_check_number$c_white);
    
ImagePng($h_img);
    
ImageDestroy($h_img);

    die();
}
/*
使用方法:
在HTML文件中加入<input type=text name=number maxlength=4><img alt=使用PHP实现登陆验证码 src=checkNumber.php?act=init>

在登陆校验PHP页面中加入以下代码(注意:在加入代码前不能有输出,因为使用了SESSION)

//$number 是你输入的校验码的值

include_once("./checkNumber.php");

//检验校验码

if($number != $login_check_number || empty($number))
{
    print("校验码不正确!");
    die();
}
*/
?> ;

使用SESSION的问题:
如果打开登陆页在SESSION的失效后才进行登陆,那么登陆会失败.
使用COOKIE的问题:
COOKIE是保存在客户端的,所以如果使用COOKIE的话还不如不用.

针对VBB论坛.保存checkNumber.php后.修改MYSQL数据库template数据表的title 为 logincode forumhome_logincode username_loggedout的template 内容.
然后在member.php的
if ($action=="login")
后加入

    //检验校验码
    include_once("./checkNumber.php");
    if($number != $login_check_number || $number == "")
    {
        print("校验码不正确!");
        die();
    }
如履薄冰

老大全是好东西,我收藏了

学得应该很实用,虽然有点看不懂,但我现在正需要这方面的东东,收藏了先

一句话。棒。不过有错误我纠正出来。
if($act == "init")
应该改为
if($_GET['act'] == "init")

坎坎坷坷

引用:
原帖由 xiaofan 于 2008-10-10 12:07 发表
一句话。棒。不过有错误我纠正出来。
if($act == "init")
应该改为
if($_GET['act'] == "init")
谢谢指出。
如履薄冰