PHP でデータベースに接続する際の一般的な落とし穴は次のとおりです: 接続検証の欠落 接続の閉じ忘れ SQL インジェクション 不適切なエラー処理 PDO を使用したクエリのパラメータ化、ユーザー入力のエスケープ、包括的なエラーの捕捉などのベスト プラクティスに従うことで、これらの落とし穴を防止し、安全で信頼性の高いデータベース接続。
PHP データベース接続の一般的な落とし穴と解決策: データを保護する
PHP でデータベースを操作する場合、あらゆるところに罠が潜んでいます。ここでは、一般的な落とし穴とそれを回避するためのベスト プラクティスをいくつか示します:
1. 接続検証が欠落している
接続を明示的に検証する mysqli_connect()
または PDO
スクリプトを使用していないconnect() メソッドの使用は予期しないエラーで失敗する可能性があります。 mysqli_connect()
或 PDO
的 connect()
方法显式验证连接的脚本可能会因不可预见的错误而失败。
// 错误代码 if (!$conn) { die("连接数据库失败!"); }
// 推荐代码:使用 PDO(推荐使用 PDO) try { $conn = new PDO($dsn, $username, $password); $conn->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION); } catch (PDOException $e) { die("连接数据库失败:" . $e->getMessage()); }
2. 忘记关闭连接
活动连接过多会耗尽服务器资源。始终在脚本结束时使用 mysqli_close()
或 PDO::close()
// 错误代码 // 忘记关闭 $conn 连接rree
2. 接続を閉じるのを忘れる
アクティブな接続が多すぎると、サーバーのリソースが枯渇します。スクリプトの最後では、mysqli_close()
または PDO::close()
を使用して常に接続を閉じることが重要です。 // 推荐代码 $conn->close(); // PDO mysqli_close($conn); // mysqli
// 错误代码:未转义用户输入 $sql = "SELECT * FROM users WHERE username='" . $_POST['username'] . "'";
3. SQL インジェクション
SQL インジェクションを使用すると、攻撃者は未検証のユーザー入力を介してデータベースに悪意のあるクエリを発行できます。パラメータ化されたクエリを使用し、ユーザー入力をエスケープまたはバインドすると、この種の攻撃を効果的に防ぐことができます。// 推荐代码:使用 PDO 参数化查询 $sql = "SELECT * FROM users WHERE username = :username"; $stmt = $conn->prepare($sql); $stmt->bindParam(':username', $_POST['username'], PDO::PARAM_STR); $stmt->execute();
// 错误代码:忽略错误 mysqli_query($conn, "SELECT * FROM missing_table");
4. エラーの不適切な処理
データベース エラーを無視したり不適切に処理すると、スクリプトが予期しない方法で終了する可能性があります。例外処理またはエラー報告メカニズムを使用して、エラーを包括的に捕捉し、有意義なフィードバックを提供します。// 推荐代码:使用 PDO 异常处理 try { $stmt = $conn->query("SELECT * FROM missing_table"); } catch (PDOException $e) { echo "执行查询出错:" . $e->getMessage(); }
// 验证连接 if (!$conn) { die("无法连接到数据库!"); } // 参数化 SQL 查询 $sql = "SELECT * FROM users WHERE username = :username AND password = :password"; $stmt = $conn->prepare($sql); $stmt->bindParam(':username', $_POST['username'], PDO::PARAM_STR); $stmt->bindParam(':password', $_POST['password'], PDO::PARAM_STR); // 执行查询 try { $stmt->execute(); } catch (PDOException $e) { echo "登录时出错:" . $e->getMessage(); } // 验证结果 $result = $stmt->fetch(); if (!$result) { echo "登录失败!用户名或密码不正确。"; } else { // 成功登录... }
実践例: 安全なユーザー ログイン
🎜🎜次のコード例は、ユーザー ログインを安全に処理する方法を示しています:🎜rrreee🎜これらのベスト プラクティスに従うことで、一般的な落とし穴を防ぎ、PHP データベース接続の安全性と信頼性を確保できます。 。 🎜以上がPHP データベース接続のよくある落とし穴と解決策: データを保護するの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。