输入无效的用户名或密码时出现pdo echo错误消息

时间:2013-05-30 11:36:57

标签: php html pdo

你好,我是相对较新的pdo(php),我创建了一个基本的登录系统,我知道它还不安全,但我只是在试验,我知道在旧的PHP你可以回应和if语句中的错误消息但它似乎不再起作用了我的脚本是我做错了什么或者你不能再在pdo那样做了。

if ($row == null){

            header( "location: login.html");
            echo "login failed";

        } else{

            header("location: homepage.php");
        }

我意识到这可能没有足够的代码可用,所以这里是脚本的其余部分

session_start();
    //connection String
    $connection = new PDO("sqlsrv:server=server;Database=database", "username", "password"); 

    //Seelcting function
    $smt = $connection->prepare("select user_id, username from account where username = :username and password =:password");

    //setting values to textboxes
    $username = $_POST["txt_username"];
    $password = $_POST["txt_password"];

    //binding values
    $smt->bindValue(':username', $username);
    $smt->bindValue(':password', $password);

    //execution
    $smt->execute();

    //fetching data
    $row = $smt->fetch( PDO::FETCH_ASSOC ) ;  
    echo "$row[user_id]\n\n";
    echo "$row[username]\n\n";
    $_SESSION{"user_id"} = $row["user_id"];

1 个答案:

答案 0 :(得分:1)

发送

header( "location: login.html");

浏览器将重定向到该新文件(login.html)并忽略(几乎)任何进一步的输出。

稍后在login.html上显示消息时,您必须使用某种机制将消息传输到该页面,例如,使用会话变量。

修改

header命令在实际内容之前向浏览器发送某种数据。如果使用标题使浏览器重定向,则用户永远不会看到内容。

因此,您需要某种方式将内容带到下一页,您将重定向到。

一种可能性是使用会话变量。

if ($row == null){
  $_SESSION['errormsg'] = "login failed";
  header( "location: login.php");
} else{
  header("location: homepage.php");
}

login.php中,如果存在,您可以对此消息作出反应:

if( isset( $_SESSION['errormsg'] ) ) {
  // do the output
  echo $_SESSION['errormsg'];
  // delete the message from the session, so that we show it only once
  unset( $_SESSION['errormsg'] );
}