ホームページ > データベース > mysql チュートリアル > Python で MySQL クエリを SQL インジェクションから保護するにはどうすればよいですか?

Python で MySQL クエリを SQL インジェクションから保護するにはどうすればよいですか?

Linda Hamilton
リリース: 2024-12-11 15:26:11
オリジナル
764 人が閲覧しました

How Can I Secure MySQL Queries in Python Against SQL Injection?

SQL インジェクションを防ぐために Python で MySQL クエリを保護する

Python から MySQL データベースにクエリを実行する場合、SQL インジェクション攻撃を防ぐことが重要です。これには、ユーザー指定の変数がクエリ構造に干渉しないようにすることが含まれます。

変数のプレースホルダーとして %s を指定した「execute」関数を使用して、パラメーター化されたクエリを実行します。実行する 2 番目のパラメーターとして変数をリストまたはタプルとして渡します。

c = db.cursor()
max_price = 5
c.execute("SELECT spam, eggs, sausage FROM breakfast WHERE price < %s", (max_price,))
ログイン後にコピー

% を使用した直接文字列置換は避けてください。代わりに、プレースホルダーとしてカンマを使用します。

c.execute("SELECT spam, eggs, sausage FROM breakfast WHERE price < %s", (max_price,))
ログイン後にコピー
ログイン後にコピー

パラメーターが文字列の場合は、プレースホルダーを一重引用符で囲まないでください。

c.execute("SELECT spam, eggs, sausage FROM breakfast WHERE price < %s", (max_price,))
ログイン後にコピー
ログイン後にコピー

次のベスト プラクティスに従うことで、次のことが可能になります。 SQL インジェクション攻撃のリスクを軽減し、Python での MySQL 接続のセキュリティを確保します。

以上がPython で MySQL クエリを SQL インジェクションから保護するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

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