Java脆弱性対策 – SQLインジェクション
SQLインジェクションってなに? 詳しい説明は、後述の参照先をご確認ください。 ざっくり言うと・・・ サイトを攻撃するための手法の1つ プログラム内でSQLを組み上げる際の間隙を狙ったニッチ産業 プログラム内でSQLを組…
Java言語プログラミングのゆるふわレシピ。コピペで使える3分クッキング♪
SQLインジェクションってなに? 詳しい説明は、後述の参照先をご確認ください。 ざっくり言うと・・・ サイトを攻撃するための手法の1つ プログラム内でSQLを組み上げる際の間隙を狙ったニッチ産業 プログラム内でSQLを組…
Webサイトを作成するにあたって、各ページごとに、すべてのコンテンツを作成するのは大変です。 メニュー、ユーザー情報の表示、ランキングの表示など、主要な部品(ウィジェット)を分割しておくことで、各ページで再利用ができます…
AESで文字列を暗号化してみます。 暗号化した後、BASE64で文字列を出力。復号します。 AESですので、暗号強度は十分だと思います。 サンプルコード
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 | import java.util.Base64; import javax.crypto.Cipher; import javax.crypto.spec.IvParameterSpec; import javax.crypto.spec.SecretKeySpec; public class CryptTest { public static String encode(String str,String encKey,String iVec,String charset) { try { SecretKeySpec key = new SecretKeySpec(encKey.getBytes(charset), "AES"); IvParameterSpec iv = new IvParameterSpec(iVec.getBytes(charset)); Cipher cipher = Cipher.getInstance("AES/CBC/PKCS5Padding"); cipher.init(Cipher.ENCRYPT_MODE, key, iv); byte[] byteResult = cipher.doFinal(str.getBytes(charset)); return Base64.getEncoder().encodeToString(byteResult); } catch (Exception e) { } return null; } public static String decode(String str,String encKey,String iVec,String charset) { try { SecretKeySpec key = new SecretKeySpec(encKey.getBytes(charset), "AES"); IvParameterSpec iv = new IvParameterSpec(iVec.getBytes(charset)); Cipher cipher = Cipher.getInstance("AES/CBC/PKCS5Padding"); cipher.init(Cipher.DECRYPT_MODE, key, iv); byte[] byteResult = cipher.doFinal(Base64.getDecoder().decode(str)); return new String(byteResult, charset); } catch (Exception e) { } return null; } public static void main(String[] args) { String str = "aaaaaa"; String encKey = "0123012301230123"; String iVec = "1234567890123456"; String charset = "UTF-8"; //encode System.out.println(encode(str,encKey,iVec,charset)); //decode System.out.println(decode(encode(str,encKey,iVec,charset),encKey,iVec,charset)); } } |
サンプルコード 半角英数字を正規表現でチェックします。
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 | import java.util.regex.Pattern; public class RegHalfAlphanumericTest { public static void main(String[] args) { //true System.out.println("a0b1c2d3e" + isHalfAlphanumeric("a0b1c2d3e")); //false System.out.println("a0b1c2d3e+" + isHalfAlphanumeric("a0b1c2d3e+")); } public static boolean isHalfAlphanumeric(String str) { return Pattern.matches("^[0-9a-zA-Z]+$", str); } } |
サンプルコードの解説 Pattern#matches(String,String)にて、チェック形…
「参照渡し」の言葉自体が物議を醸していたりしますが・・・。内容については、ここでは語りません。 とは言え、「参照渡し」は一般的に普及した言葉ですので、とりあえずこの言葉を使います。 いぢわるな例(ふつう、こうは書かない)…
よく使う半角数字の入力。 これを正規表現でチェックします。 Youtube版はこちらからどうぞ Youtubeで動画を公開しました。こちらもぜひぜひ。 半角数字をチェックするサンプル 半角数字を正規表現でチェックします。…
半角カナと同じく、フリガナでよく使われます。 このチェックも正規表現を使えば、簡単にチェックできます。 全角カナをチェックするサンプル
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 | import java.util.regex.Pattern; public class RegFullKanaTest { public static void main(String[] args) { //true System.out.println("ビッグジャナクテビックダヨ" + isFullKana("ビッグジャナクテビックダヨ")); //false System.out.println("ヤバイよヤバイよ" + isFullKana("ヤバイよヤバイよ")); } public static boolean isFullKana(String str) { return Pattern.matches("^[ァ-ヶー]*$", str); } } |
サンプルの解説 P…
フリガナでよく使う、半角カナ。 これを正規表現でチェックします。 半角カナをチェックするサンプル
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 | import java.util.regex.Pattern; public class RegHalfKanaTest { public static void main(String[] args) { //true System.out.println("ホゲホゲ" + isHalfKana("ホゲホゲ")); //false System.out.println("ヤバイ!マザッタ" + isHalfKana("ヤバイ!マザッタ")); } public static boolean isHalfKana(String str) { return Pattern.matches("^[ヲ-゚]*$", str); } } |
サンプルの解説 Pattern#matches(Stri…
業務アプリケーションではあまり使用しないかもしれませんが、パソコン等の端末情報を持つようなシステムでは、IPアドレスを登録する場合があります。 IPアドレス(v4)をチェックするサンプル さっそく、正規表現を使って、IP…
Webサイトでよくある郵便番号の入力。 サーバー側では、正規表現を使うと、こんな感じでチェックできます。 郵便番号をチェックするサンプル
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 | import java.util.regex.Pattern; public class RegZipCodeTest { public static void main(String[] args) { // //ハイフン付きで郵便番号チェック // //true System.out.println("111-2222:" + isZipCode1("111-2222")); //false System.out.println("1a1-2222:" + isZipCode1("1a1-2222")); System.out.println("111-22:" + isZipCode1("111-22")); System.out.println("11112222:" + isZipCode1("11112222")); // //ハイフンなしで郵便番号チェック // //true System.out.println("1112222:" + isZipCode2("1112222")); //false System.out.println("1a12222:" + isZipCode2("1a12222")); System.out.println("11122:" + isZipCode2("11122")); System.out.println("1112222:" + isZipCode2("1112222")); } public static boolean isZipCode1(String str) { //ハイフン付きで郵便番号チェック return Pattern.matches("^[0-9]{3}-[0-9]{4}$", str); } public static boolean isZipCode2(String str) { //ハイフンなしで郵便番号チェック return Pattern.matches("^[0-9]{7}$", str); } } |
サンプルの解説 …