2

整个代码:

<?php 

if (isset($_POST['usname']) && isset($_POST['pasw'])){

    $username = mysql_ramznegar($_POST['usname'],$link);
    $password = mysql_ramznegar($_POST['pasw'],$link);

$query = "SELECT * FROM `admin` WHERE `usname` = $username";
    $admin_result = mysql_query($query,$link);
    $admin_result = mysql_fetch_array($query,MYSQL_ASSOC);

    if($admin_result['usname']==$username && $admin_result['passw']==$password){


            if($admin_result[usname] == "admin"){

            $_SESSION['auth'] = 1;

                redirect("panel");

                   exit;                                

    }
     else{

        echo 'ur username or password is invalid';
        redirect("index.php");
     }


}

}

?>

我有一个带有两列的表(管理员)的数据库,第一列是usname,第二列是passw,但是当我输入用户名和密码编译器向我显示此错误时,我选择了查询,我该如何解决此编译器警告:

警告:mysql_fetch_array() 期望参数 1 是资源,第 60 行 C:\xampp\htdocs\ramznegar1\index.php 中给出的字符串

你应该改变

$admin_result = mysql_fetch_array($query, MYSQL_ASSOC)

$admin_result = mysql_fetch_array($admin_result, MYSQL_ASSOC)

我编辑了我的代码,但我又遇到了这个错误:

警告:mysql_fetch_array() 期望参数 1 是资源,布尔值在第 60 行的 C:\xampp\htdocs\ramznegar1\index.php 中给出

新代码是: http: //pastebin.com/ycNT0XqM

4

2 回答 2

2

你应该改变:

$query = "SELECT * FROM `admin` WHERE `usname` = $username";
$admin_result = mysql_query($query,$link);
$admin_result = mysql_fetch_array($query,MYSQL_ASSOC);

$query = "SELECT * FROM `admin` WHERE `usname` = $username"; 
$admin_result = mysqli_query($query,$link); 
$admin_result = mysqli_fetch_array($admin_result,MYSQL_ASSOC);

有关 mysql_fetch_array 如何工作的信息,请参阅http://php.net/manual/en/function.mysql-fetch-array.php

于 2012-10-10T21:46:59.333 回答
1

你应该改变

 $admin_result = mysql_fetch_array($query, MYSQL_ASSOC)

 $admin_result = mysql_fetch_array($admin_result, MYSQL_ASSOC)

mysql_ 上的 PHP 文档*

不鼓励使用此扩展程序。相反,应该使用 MySQLi 或 PDO_MySQL 扩展。另请参阅 MySQL:选择 API 指南和相关的常见问题解答以获取更多信息。此功能的替代方案包括:

于 2012-10-10T21:46:11.683 回答