mysqli连接并从数据库中选择错误

Posted

技术标签:

【中文标题】mysqli连接并从数据库中选择错误【英文标题】:mysqli connect and select from database error 【发布时间】:2014-04-12 19:03:59 【问题描述】:

我最近开始使用mysqli_连接我的数据库,因为担心sql注入和缺乏安全性。我正在尝试使用 mysql 中的 mysqli 重新配置我的登录页面,但该页面无法加载,我不知道为什么。提前感谢您的帮助。

这是我的代码:

<?php
$mysqli = new mysqli("localhost", "username", "password", "db");

if($mysqli->connect_errno > 0)
    die('Unable to connect to database [' . $mysqli->connect_error . ']');


if (!isset($_SESSION['email'])) 

$e = trim($_REQUEST['email']);
$email = mysqli->real_escape_string($e);
$p = trim($_REQUEST['password']);
$password = mysqli->real_escape_string($p);

if ($result = $mysqli->query("SELECT email, password" .
                                             " FROM users" .
                                             " WHERE email = '".$email."' AND password = '".$password."'")) 
    printf("Select returned %d rows.\n", $result->num_rows);

if ($result->num_rows == 1) 
$row = $result->fetch_array(MYSQLI_NUM);
   $user_id = $ow['user_id'];
   //No more setcookie
   $_SESSION['user_id'] = $user_id;
   $_SESSION['email'] = $email;


    /* free result set */
    $result->close();



?>
<html>
<head>

<title>Login</title>

</head>
<body>

<form id="signin_form"
               action="<?php echo $_SERVER['PHP_SELF']; ?>"
               method="POST">
      <div class="signin_box">
         <label for="email">Email or Username:</label><br>
         <input type="text" name="email" id="email" size="30" />
         <br />
         <label for="password">Password:</label>
         <input type="password" name="password" id="password" size="30" />

     <br />
<span class="signin_submit">
        <input type="submit" value="Sign In" class="signin_submit" />
</span>
     </div>
   </form>

</body>
</html>

【问题讨论】:

【参考方案1】:

这里

$email = mysqli->real_escape_string($e);

你忘了$

$email = $mysqli->real_escape_string($e);

$password = mysqli->real_escape_string($p);

$password = $mysqli->real_escape_string($p);

【讨论】:

以上是关于mysqli连接并从数据库中选择错误的主要内容,如果未能解决你的问题,请参考以下文章

尝试从数据库中选择 WooCommerce 值时出现 mysqli_fetch_assoc 错误

PHP : MySQLi面向过程操作数据库 连接建库建表增删改查关闭

使用php跨服务器的mysqli连接错误

php操作数据库

Pyspark:内部连接两个 pyspark 数据帧并从第一个数据帧中选择所有列,从第二个数据帧中选择几列

mysqli操作数据库