0

私はこれで3時間ほど座っていますが、この問題を解決できません。

ログインしようとするたびに、エラーが表示されます (ユーザーが見つかりません)。

ログイン機能は次のとおりです。

if($_SERVER['REQUEST_METHOD'] === 'POST' && $_POST['submit']=="login") {
    if(!empty($_POST['username']) && !empty($_POST['password']) && checkAnum($_POST['username']) && checkAnum($_POST['password'])) 
    {

      $Cmdlogin = "SELECT * FROM database.account WHERE username='".$_POST['username']."' AND password=PASSWORD('".$_POST['password']."') LIMIT 1";
      $sqllogin = mysqli_query($sqlHp,$Cmdlogin);
      if(mysqli_num_rows($sqllogin)>0)
      {
        $getAdmin = mysqli_fetch_object($sqllogin);
        $_SESSION['user_id'] = $getAdmin->id;
        $_SESSION["user_username"] = $getAdmin->username;
     }else{echo'error';}
    }
  }

そして、ここにフォームがあります:

<FORM action="index.php?s=login" method="POST">
                <TD>
                    <TABLE>
                        <TR>
                            <TD align="left">Username</TD>
                            <TD align="left"><input type="text" name="username" maxlength="15"/></TD>
                        </TR>
                        <TR>
                            <TD align="left">Password</TD>
                            <TD align="left"><input type="password" name="password" maxlength="30"/></TD>
                        </TR>
                    </TABLE>
                    <BR>
    <input type="submit" class="button" value="login" name="submit" />
</FORM>

誰が何が悪いのか知っていますか?理解できません。現時点では本当に夢中になっており、スタックオーバーフローは私にとって最後の希望です。

編集:修正しました。パスワード行の長さの設定が 30 を超えていましたが、パスワードには 30 文字以上が必要でした。

4

2 に答える 2

0

変数に $_POST を入れるべきだと思います

$user = $_POST['username'];
$pass = $_POST['password'];
$Cmdlogin = "SELECT * FROM database.account WHERE username='".$user."' AND password=PASSWORD('" . $pass . "')' LIMIT 1";
于 2013-11-07T06:44:31.500 に答える
0

追加session_start();

session_start();
$_SESSION['user_id'] = $getAdmin->id;
$_SESSION["user_username"] = $getAdmin->username;
于 2013-11-07T05:50:09.737 に答える