使用PHP实现登陆验证码

<?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_img, 0,0,0);
    $c_white = ImageColorAllocate($h_img, 255,255,255);
    imageline($h_img, 1, 1, 350, 25, $c_black);
    imagearc($h_img, 200, 15, 20, 20, 35, 190, $c_white);
    imagestring($h_img, 5, 2, 1, $login_check_number, $c_white);
    ImagePng($h_img);
    ImageDestroy($h_img);

    die();
}
/*
使用方法:
在HTML文件中加入<input type=text name=number maxlength=4><img 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();
    } 
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,针对您的需求,我可以提供以下步骤来实现用户登录功能并引入验证码: 1. 创建一个登录页面,包括用户名和密码的输入框,以及一个验证码输入框和验证码图片。 2. 生成验证码图片,并将验证码存储在 session 中,用于后面的验证。 3. 用户输入用户名、密码和验证码,提交表单。 4. 服务器接收表单数据,首先验证验证码是否正确,如果不正确则返回错误信息,让用户重新输入。 5. 如果验证码正确,则对用户名和密码进行验证。如果验证成功,将用户信息存储在 session 中,并跳转到登录成功的页面。 下面是 PHP 代码示例: 1. 生成验证码图片并存储在 session 中 ```php session_start(); $code = rand(1000, 9999); $_SESSION['code'] = $code; $im = imagecreatetruecolor(50, 20); $bgColor = imagecolorallocate($im, 255, 255, 255); $fontColor = imagecolorallocate($im, 0, 0, 0); imagefill($im, 0, 0, $bgColor); imagestring($im, 5, 5, 2, $code, $fontColor); header("Content-type: image/png"); imagepng($im); imagedestroy($im); ``` 2. 验证表单数据 ```php session_start(); if ($_POST['code'] != $_SESSION['code']) { die("验证码错误!"); } $username = $_POST['username']; $password = $_POST['password']; // 验证用户名和密码是否正确 if ($username == 'admin' && $password == '123456') { // 将用户信息存储在 session 中 $_SESSION['username'] = $username; header("Location: success.php"); } else { die("用户名或密码错误!"); } ``` 希望这些步骤可以帮助您实现所需的功能。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值