ホームページ >データベース >mysql チュートリアル >安全なデータベース相互作用のために、古い「mysql_*」関数を PDO およびプリペアドステートメントに置き換えるにはどうすればよいですか?

安全なデータベース相互作用のために、古い「mysql_*」関数を PDO およびプリペアドステートメントに置き換えるにはどうすればよいですか?

Linda Hamilton
Linda Hamiltonオリジナル
2024-11-06 13:42:02419ブラウズ

How to Replace Outdated `mysql_*` Functions with PDO and Prepared Statements for Secure Database Interactions?

mysql_* 関数を PDO およびプリペアド ステートメントで置き換える

質問:

古い mysql_* 関数を次のステートメントに置き換えるにはどうすればよいですか? PDO とプリペアド ステートメントを使用して、データベースにデータを安全に保存したりデータベースから取得したりできますか?

答え:

  1. PDO 接続を確立します:
$hostname = '*host*';
$username = '*user*';
$password = '*pass*';
$database = '*database*';

$dbh = new PDO("mysql:host=$hostname;dbname=$database", $username, $password);
  1. データの挿入にプリペアド ステートメントを使用する:
$username = $_POST['username'];
$email = $_POST['email'];

$stmt = $dbh->prepare("INSERT INTO `users` (username, email)
                        VALUES (?, ?)");

$stmt->bindParam(1, $username, PDO::PARAM_STR);
$stmt->bindParam(2, $email, PDO::PARAM_STR);

$stmt->execute();
  1. BindParam の長さパラメーター:

PDO::PARAM_STR には長さパラメーターは必要ありません。ただし、データベース テーブルのフィールドに最大文字数制限がある場合は、以下に示すように PDO::PARAM_STR の後にそれを指定できます。

$stmt->bindParam(1, $username, PDO::PARAM_STR, 255);
  1. データを取得するための準備されたステートメント:
$user_id = $_GET['id'];

$stmt = $dbh->prepare("SELECT * FROM `users` WHERE `id` = ?");

$stmt->bindParam(1, $user_id, PDO::PARAM_INT);
  1. さまざまなデータ型でのbindParamの使用:
  • 文字列のPDO::PARAM_STR
  • 整数の場合は PDO::PARAM_INT
  • ブール値の場合は PDO::PARAM_BOOL
  1. 安全性:
  • プリペアド ステートメントを使用すると、mysql_real_escape_string などの関数を使用して手動で文字列をエスケープする必要がなくなります。
  • PDO はクエリの実行を安全に処理し、SQL インジェクションの脆弱性を防ぎます。
  • ただし、注意することが重要です。準備されたステートメントだけではセキュリティは保証されません。入力検証と適切なサニタイズ措置を引き続き実施する必要があります。

以上が安全なデータベース相互作用のために、古い「mysql_*」関数を PDO およびプリペアドステートメントに置き換えるにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。