mysql ライブラリから PDO に移行するときのよくある質問の 1 つは、real_escape_string 関数の置き換えに関するものです。この記事では、PDO を使用して文字列をエスケープするための推奨方法について詳しく説明します。
PDO で文字列をエスケープするための推奨方法は、PDO::prepare() を使用することです。この機能を使用すると、異なるパラメータ値を使用して複数回実行できる準備済みステートメントを作成できます。プリペアド ステートメントを使用すると、SQL インジェクション攻撃を防止し、アプリケーションのパフォーマンスを最適化できます。
PDO プリペアド ステートメントは、SQL クエリをパラメータから分離することで機能します。これにより、PDO ドライバーはステートメントのクエリ プランとメタ情報を最適化できます。準備されたステートメントを実行するときは、パラメーター値を配列として指定します。 PDO はこれらの値を自動的に引用符で囲んでエスケープするため、手動で文字列を引用符で囲む必要がなくなります。
ここでは、PDO Prepare を使用して文字列をエスケープする方法の例を示します:
<code class="php">$statement = $pdo->prepare("INSERT INTO users (name, email) VALUES (:name, :email)"); $statement->bindParam(':name', $name); $statement->bindParam(':email', $email); $statement->execute();</code>
この例では、準備されたステートメントの実行時に、:name および :email プレースホルダーが指定されたパラメーター値に置き換えられます。 PDO はこれらの値をデータベースに挿入する前に自動的にエスケープし、SQL インジェクションを防ぎます。
PDO Prepare を使用すると、文字列を簡単にエスケープし、SQL インジェクション攻撃を防ぐことができます。このアプローチは安全かつ効率的であり、PDO クエリのパフォーマンスを最適化します。
以上がPDO を使用して文字列をエスケープし、SQL インジェクションを防ぐ方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。