$result = $conn->query($sql);和$result =mysqli_query($sql)
时间: 2023-12-31 09:06:23 浏览: 37
这两行代码的作用是执行 SQL 查询语句,但是它们使用的是不同的 PHP 数据库扩展。
第一行代码使用的是 PDO 扩展,其中 $conn 是一个 PDO 类型的数据库连接对象。查询结果会被封装在 $result 变量中,它是一个 PDOStatement 类型的对象。
第二行代码使用的是 mysqli 扩展,其中 $sql 是一个包含 SQL 查询语句的字符串。查询结果会被封装在 $result 变量中,它是一个 mysqli_result 类型的对象。
需要注意的是,这两个扩展的用法和语法有所不同,需要根据具体情况选择使用哪一个。同时,为了保证代码的安全性和可靠性,还需要注意 SQL 注入等安全问题。
相关问题
<?php $servername = "localhost"; $username = "yourusername"; $password = "yourpassword"; $dbname = "yourdatabase"; // 创建连接 $conn = new mysqli($servername, $username, $password, $dbname); // 检查连接是否成功 if ($conn->connect_error) { die("连接失败: " . $conn->connect_error); } // 获取表单提交的用户名和密码 $username = $_POST['username']; $password = $_POST['password']; // 查询用户表中是否存在该用户 $sql = "SELECT * FROM users WHERE username='$username' AND password='$password'"; $result = $conn->query($sql); // 判断查询结果是否为空 if ($result->num_rows > 0) { echo "登录成功!"; } else { echo "用户名或密码错误!"; } // 关闭连接 $conn->close(); ?> 使用密码哈希加密
好的,下面是使用密码哈希加密的代码,该代码实现了与MySQL数据库的连接和登录验证并使用了密码哈希加密:
HTML登录页面:
```
<!DOCTYPE html>
<html>
<head>
<title>登录页面</title>
</head>
<body>
<h2>登录</h2>
<form method="post" action="login.php">
<label>用户名:</label><input type="text" name="username" required><br>
<label>密码:</label><input type="password" name="password" required><br>
<input type="submit" value="登录">
</form>
</body>
</html>
```
login.php文件:
```
<?php
$servername = "localhost";
$username = "yourusername";
$password = "yourpassword";
$dbname = "yourdatabase";
// 创建连接
$conn = new mysqli($servername, $username, $password, $dbname);
// 检查连接是否成功
if ($conn->connect_error) {
die("连接失败: " . $conn->connect_error);
}
// 获取表单提交的用户名和密码
$username = $_POST['username'];
$password = $_POST['password'];
// 使用密码哈希加密
$hashed_password = password_hash($password, PASSWORD_DEFAULT);
// 查询用户表中是否存在该用户
$sql = "SELECT * FROM users WHERE username='$username'";
$result = $conn->query($sql);
// 判断查询结果是否为空
if ($result->num_rows > 0) {
// 获取密码哈希
$row = $result->fetch_assoc();
$hashed_password_db = $row['password'];
// 验证密码
if (password_verify($password, $hashed_password_db)) {
echo "登录成功!";
} else {
echo "用户名或密码错误!";
}
} else {
echo "用户名或密码错误!";
}
// 关闭连接
$conn->close();
?>
```
请注意,此处使用了PHP内置的password_hash()和password_verify()函数来实现密码哈希加密和验证。
$result = mysqli_query($conn, $sql);
这行代码使用了 PHP 中的 mysqli 扩展库提供的函数 mysqli_query(),用于向 MySQL 数据库发送查询语句并返回查询结果。其中 $conn 是一个已连接到 MySQL 数据库的 mysqli 对象,$sql 是一个包含 SQL 查询语句的字符串。执行该语句后,如果查询成功,将返回一个 mysqli_result 对象,可以通过该对象读取查询结果的数据行。如果查询失败,将返回 false。