<?php
  require "head.php";
  $u_name = $_POST[username];
  $u_pass = $_POST[password];  if ($u_name == "" || $u_pass == "" ) { echo "<script language='javascript'>\n"; echo "alert('用户名和密码不能为空!');\n"; echo "history.go(-1);\n"; echo "</script>\n"; exit; }  $tmp = query_first("SELECT * FROM dbuser WHERE name = '$u_name'");
if($tmp[name] == ""){
        error_quit("帐号不存在!");
    } if($tmp[password] != $password){
        error_quit("密码错误!");
    }
?>
我现在将代码改写成如上所示,但还是错误,谁指点一二呀!

解决方案 »

  1.   

    目前,不少网站为了防止用户利用机器人自动注册、登录、灌水,都采用了 
    验证码技术。所谓验证码,就是将一串随机产生的数字或符号,生成一幅图片,图片里加上一些干扰象素(防止OCR),由用户肉眼识别其中的验证码信息,输 
    入表单提交网站验证,验证成功后才能使用某项功能。 我们这里展示了如何编写PHP程序实现验证码功能: 代码一:
    Code: [Copy to clipboard] 
    <?php 
    /* 
    * Filename: authpage.php 
    * Author: hutuworm 
    * Date: 2003-04-28 
    * @Copyleft hutuworm.org 
    */ srand((double)microtime()*1000000); //验证用户输入是否和验证码一致 
    if(isset($HTTP_POST_VARS['authinput'])) 

    if(strcmp($HTTP_POST_VARS['authnum'],$HTTP_POST_VARS['authinput'])==0) 
    echo "验证成功!"; 
    else 
    echo "验证失败!"; 
    } //生成新的四位整数验证码 
    while(($authnum=rand()%10000)<1000); 
    ?> 
    <form action=authpage.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> 代码二
    Code: [Copy to clipboard] 
    :<?php
    /* 
    * Filename: authimg.php 
    * Author: hutuworm 
    * Date: 2003-04-28 
    * @Copyleft hutuworm.org 
    */ //生成验证码图片 
    Header("Content-type: image/PNG"); 
    srand((double)microtime()*1000000); 
    $im = imagecreate(58,28); 
    $black = ImageColorAllocate($im, 0,0,0); 
    $white = ImageColorAllocate($im, 255,255,255); 
    $gray = ImageColorAllocate($im, 200,200,200); 
    imagefill($im,68,30,$gray); //将四位整数验证码绘入图片 
    imagestring($im, 5, 10, 8, $HTTP_GET_VARS['authnum'], $black); for($i=0;$i<50;$i++) //加入干扰象素 

    imagesetpixel($im, rand()%70 , rand()%30 , $black); 
    } ImagePNG($im); 
    ImageDestroy($im); 
    ?> 本文程序在Apache 2.0.45 + PHP 4.3.1环境下运行通过。 上文只是对验证码功能的一个简单实现,并没有考虑商用安全性问题。如果要增强安全性,将此功能投入商业应用,则可以通过以下几个步骤实现: 1. 启用Session。 
    2. authnum在authimg.php中生成,并计算md5sum,存入session。 
    3. authpage.php将authinput计算md5sum后,与session中的authnum(md5sum)对比得出验证结果。
    本站注:作者使用了简单的代码实现了很酷的功能。不过在添加干扰像素时的效果不是太好,大家可以看一下雨声论坛登录时的效验码(http://ror.cn/perl/ut/user_login.cgi),偶把第二段代码稍改了一下,生成了与其类似的效果。修改后的代码如下:
    Code: [Copy to clipboard] 
    <?php 
    /* 
    * Filename: authimg.php 
    * Author: hutuworm 
    * Date: 2003-04-28 
    * @Copyleft hutuworm.org 
    */ 
    //生成验证码图片 
    Header("Content-type: image/PNG"); 
    srand((double)microtime()*1000000); 
    $im = imagecreate(62,20); 
    $black = ImageColorAllocate($im, 0,0,0); 
    $white = ImageColorAllocate($im, 255,255,255); 
    $gray = ImageColorAllocate($im, 200,200,200); 
    imagefill($im,68,30,$gray); 
    while(($authnum=rand()%100000)<10000);
    //将四位整数验证码绘入图片 
    imagestring($im, 5, 10, 3, $authnum, $black); 
    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); 
    ?>
      

  2.   

    你说说你的代码的错误是什么吧?
    query_first
    error_quit
    这两个函数对吗?