[解決済み] Java - SQLインジェクションを防止するためのエスケープ文字列
2022-04-27 01:36:40
質問
私はjavaでいくつかのアンチsqlインジェクションを配置しようとしていますが、"replaceAll"文字列関数を扱うのが非常に困難であることが分かっています。最終的には、既存の文字列を変換する関数が必要です。
\
を
\\
は、任意の
"
から
\"
は、任意の
'
から
\'
と、任意の
\n
から
\\n
この文字列がMySQLで評価されるとき、SQLインジェクションがブロックされるようにするためです。
私が作業していたあるコードをジャックしたところ、すべての
\\\\\\\\\\\
の関数で、目がおかしくなりそうです。もし、どなたかこのような例をお持ちでしたら、ぜひ教えてください。
どのように解決するのですか?
PreparedStatementsは、SQLインジェクションを不可能にするので、この方法がお勧めです。 ここでは、ユーザーの入力をパラメータとした簡単な例を示します。
public insertUser(String name, String email) {
Connection conn = null;
PreparedStatement stmt = null;
try {
conn = setupTheDatabaseConnectionSomehow();
stmt = conn.prepareStatement("INSERT INTO person (name, email) values (?, ?)");
stmt.setString(1, name);
stmt.setString(2, email);
stmt.executeUpdate();
}
finally {
try {
if (stmt != null) { stmt.close(); }
}
catch (Exception e) {
// log this error
}
try {
if (conn != null) { conn.close(); }
}
catch (Exception e) {
// log this error
}
}
}
nameとemailにどんな文字があっても、それらの文字は直接データベースに配置されます。 これらは、INSERT文に何ら影響を与えません。
データ型によって異なるセット方法があり、どれを使うかは、データベースのフィールドが何であるかによります。 たとえば、データベースに INTEGER カラムがある場合、そのカラムに対して
setInt
メソッドを使用します。
PreparedStatementのドキュメント
には、データの設定や取得に使用できるすべてのメソッドがリストアップされています。
関連
-
javaでよく使われる英単語
-
SocketTimeoutExceptionの解決方法です。読み込みがタイムアウトした
-
[解決済み] JavaでInputStreamを読み込んでStringに変換するにはどうすればよいですか?
-
[解決済み] JavaでNullPointerExceptionを回避する方法
-
[解決済み] JavaにおけるHashMapとHashtableの違いは何ですか?
-
[解決済み] SQL ServerでSELECTからUPDATEする方法とは?
-
[解決済み] なぜパスワードにはStringではなくchar[]が好まれるのですか?
-
[解決済み] Javaでメモリーリークを発生させるにはどうしたらいいですか?
-
[解決済み] JavaでStringをintに変換するにはどうしたらいいですか?
-
[解決済み] PHPでSQLインジェクションを防ぐにはどうしたらいいですか?
最新
-
nginxです。[emerg] 0.0.0.0:80 への bind() に失敗しました (98: アドレスは既に使用中です)
-
htmlページでギリシャ文字を使うには
-
ピュアhtml+cssでの要素読み込み効果
-
純粋なhtml + cssで五輪を実現するサンプルコード
-
ナビゲーションバー・ドロップダウンメニューのHTML+CSSサンプルコード
-
タイピング効果を実現するピュアhtml+css
-
htmlの選択ボックスのプレースホルダー作成に関する質問
-
html css3 伸縮しない 画像表示効果
-
トップナビゲーションバーメニュー作成用HTML+CSS
-
html+css 実装 サイバーパンク風ボタン
おすすめ
-
java.util.NoSuchElementException 原因解析と解決方法
-
Java Error スレッド "AWT-EventQueue-0" で例外発生 java.lang.
-
undefinedeclipse エラー。この行に複数のアノテーションが見つかりました: - 文字列を型解決に解決できない
-
をインスタンス化することができません。
-
Enumとの組み合わせでswitchの使い方を一度覚えるために必要な定数式
-
Eclipseプロンプトを実行する java仮想マシンを使用しない
-
エラーの解決方法 jarfile XXX.jarにアクセスできません。
-
javaでクラスを作成すると、enclosing classでないように見える
-
スレッド "main" で例外発生 java.net.BindException: アドレスは既に使用中です。NET_Bind
-
このラインで複数のマーカーを解決する方法