ホームページ > データベース > mysql チュートリアル > 「mysql_real_escape_string()」は SQL インジェクションに対してまだ安全ですか?

「mysql_real_escape_string()」は SQL インジェクションに対してまだ安全ですか?

Susan Sarandon
リリース: 2024-12-07 14:41:11
オリジナル
783 人が閲覧しました

Is `mysql_real_escape_string()` Still Secure Against SQL Injection?

mysql_real_escape_string() は壊れた関数ですか?

にもかかわらず、SQL インジェクションの脆弱性を軽減する mysql_real_escape_string() の有効性について懸念が提起されています。正しい使い方。懐疑論者は、その欠陥の証拠として時代遅れの記事を挙げています。

mysql_real_escape_string() はまだ利用できますか?

この質問に答えるために、MySQL C API ドキュメントを詳しく調べます。 mysql_real_escape_string():

「接続の文字セットを変更する必要がある場合は、SET NAMES を実行する代わりに mysql_set_character_set() を使用してください。」

コードデモ:

mysql_real_escape_string()
ログイン後にコピー

説明:

ドキュメントによると、mysql_set_character_set() は、SET NAMES とは異なり、mysql_real_escape_string() で使用される文字セットに影響します。したがって、PHP アプリケーションのエンコーディングを変更するには、mysql_set_charset() を使用する必要があります。

結論:

mysql_real_escape_string() は完全に壊れているわけではないかもしれませんが、必ず変更する必要があります。 mysql_set_character_set() と組み合わせて使用​​すると、適切な文字セット処理が保証され、潜在的な SQL インジェクションが防止されます。脆弱性。

以上が「mysql_real_escape_string()」は SQL インジェクションに対してまだ安全ですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
著者別の最新記事
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート