0

こんにちは、私はこのコードを持っていて、関数 evalLoggedUser に問題があると思います...現在、関数は間違った出力を表示し (true ではなく false を返します)、関数内の if ステートメントを変更すると、次のようになります。

if($numrows == 0) {
    return true;
}

それは私が望むように動作します...しかし、私はこのように動作し、if ステートメントは if($numrows > 0) のようになりたいです。私は一日中検索してこれを理解しようとしていますが、何もありません... $numrows varをエコーし​​ようとしましたが、何もエコーしません...また、dbエラーをエコーし​​ましたが、すべて問題ありません。どんな助けでも大歓迎です。前もって感謝します。

<?php
session_start();
include_once("../db_includes/db_conx.php");
$user_ok = false;
$log_id = "";
$log_username = "";
$log_password = "";
// User Verify function
function evalLoggedUser($db_conx,$id,$u,$p){
    $sql = "SELECT ip FROM users WHERE id='$id' AND username='$u' AND password='$p' AND activated='1' LIMIT 1";
    $query = mysqli_query($db_conx, $sql);
    $numrows = mysqli_num_rows($query);
    if($numrows > 0){  
        return true;
    }
}
if(isset($_SESSION["userid"]) && isset($_SESSION["username"]) && isset($_SESSION["password"])) {
$log_id = preg_replace('#[^0-9]#', '', $_SESSION['userid']);
$log_username = preg_replace('#[^a-z0-9]#i', '', $_SESSION['username']);
$log_password = preg_replace('#[^a-z0-9]#i', '', $_SESSION['password']);
// Verify the user
$user_ok = evalLoggedUser($db_conx,$log_id,$log_username,$log_password);
} else if(isset($_COOKIE["id"]) && isset($_COOKIE["user"]) && isset($_COOKIE["pass"])){
$_SESSION['userid'] = preg_replace('#[^0-9]#', '', $_COOKIE['id']);
    $_SESSION['username'] = preg_replace('#[^a-z0-9]#i', '', $_COOKIE['user']);
    $_SESSION['password'] = preg_replace('#[^a-z0-9]#i', '', $_COOKIE['pass']);
$log_id = $_SESSION['userid'];
$log_username = $_SESSION['username'];
$log_password = $_SESSION['password'];
// Verify the user
$user_ok = evalLoggedUser($db_conx,$log_id,$log_username,$log_password);
if($user_ok == true){
// Update their lastlogin datetime field
$sql = "UPDATE users SET lastlogin=now() WHERE id='$log_id' LIMIT 1";
        $query = mysqli_query($db_conx, $sql);
}
}
?>
4

2 に答える 2

-1

確かに答えるには未知数が多すぎるので、これを試してください。SQL ステートメントに続く関数内のコードを次のように置き換えます。

if (($result = $db_conx->query($sql)) === false) {
   $errmsg .= '<p><b>User Eval:</b> ' . $db_conx->error . '</p><p>' . $sql . '</p>';
   echo $errmsg;
} elseif (!$result->num_rows) {
   //no records, so user cannot log in
} else {
    //return a true value in here
}

一度実行すると、何が間違っているかを正確に確認できるはずです

于 2013-09-24T04:00:30.203 に答える