티스토리 뷰
참고 블로그 보기
Java로 AES128 암호화를 위한 소스코드 입니다.
웹 서치를 통해 찾은 코드이며, AES의 키는 128, 192, 256bit를 지원하기 때문에
128bit를 사용하기 위해서는 key를 16문자(8*16byte)로 지정을 해야 한다고 하지만
더 길게 지정해도 크게 문제는 발생하기 않았습니다.
사용한 key는 31문자로 지원하는 key의 bit와는 맞지는 않았지만 16문자와 31문자 모두
암호화된 결과물은 32문자로 생성되었습니다.
(물론, 암호화 결과는 달랐습니다 ^^;)
웹 서치를 통해 찾은 코드이며, AES의 키는 128, 192, 256bit를 지원하기 때문에
128bit를 사용하기 위해서는 key를 16문자(8*16byte)로 지정을 해야 한다고 하지만
더 길게 지정해도 크게 문제는 발생하기 않았습니다.
사용한 key는 31문자로 지원하는 key의 bit와는 맞지는 않았지만 16문자와 31문자 모두
암호화된 결과물은 32문자로 생성되었습니다.
(물론, 암호화 결과는 달랐습니다 ^^;)
import java.security.SecureRandom; import javax.crypto.Cipher; import javax.crypto.KeyGenerator; import javax.crypto.SecretKey; import javax.crypto.spec.SecretKeySpec; /** * Usage: ** String crypto = SimpleCrypto.encrypt(masterpassword, cleartext) * ... * String cleartext = SimpleCrypto.decrypt(masterpassword, crypto) ** @author ferenc.hechler */ public class CryptoManager { private final static String HEX = "0123456789ABCDEF"; public static String encrypt(String seed, String cleartext) throws Exception { byte[] rawKey = getRawKey(seed.getBytes()); byte[] result = encrypt(rawKey, cleartext.getBytes()); return toHex(result); } private static byte[] encrypt(byte[] raw, byte[] clear) throws Exception { SecretKeySpec skeySpec = new SecretKeySpec(raw, "AES"); Cipher cipher = Cipher.getInstance("AES"); cipher.init(Cipher.ENCRYPT_MODE, skeySpec); byte[] encrypted = cipher.doFinal(clear); return encrypted; } public static String decrypt(String seed, String encrypted) throws Exception { byte[] rawKey = getRawKey(seed.getBytes()); byte[] enc = toByte(encrypted); byte[] result = decrypt(rawKey, enc); return new String(result); } private static byte[] decrypt(byte[] raw, byte[] encrypted) throws Exception { SecretKeySpec skeySpec = new SecretKeySpec(raw, "AES"); Cipher cipher = Cipher.getInstance("AES"); cipher.init(Cipher.DECRYPT_MODE, skeySpec); byte[] decrypted = cipher.doFinal(encrypted); return decrypted; } private static byte[] getRawKey(byte[] seed) throws Exception { KeyGenerator kgen = KeyGenerator.getInstance("AES"); SecureRandom sr = SecureRandom.getInstance("SHA1PRNG"); sr.setSeed(seed); kgen.init(128, sr); // 192 and 256 bits may not be available SecretKey skey = kgen.generateKey(); byte[] raw = skey.getEncoded(); return raw; } public static String toHex(String txt) { return toHex(txt.getBytes()); } public static String toHex(byte[] buf) { if (buf == null) return ""; StringBuffer result = new StringBuffer(2 * buf.length); for (int i = 0; i < buf.length; i++) { appendHex(result, buf[i]); } return result.toString(); } public static String fromHex(String hex) { return new String(toByte(hex)); } public static byte[] toByte(String hexString) { int len = hexString.length() / 2; byte[] result = new byte[len]; for (int i = 0; i < len; i++) { result[i] = Integer.valueOf(hexString.substring(2 * i, 2 * i + 2), 16).byteValue(); } return result; } private static void appendHex(StringBuffer sb, byte b) { sb.append(HEX.charAt((b >> 4) & 0x0f)).append(HEX.charAt(b & 0x0f)); } }
댓글
공지사항
최근에 올라온 글
최근에 달린 댓글
- Total
- Today
- Yesterday
링크
TAG
- 케이카 워런티
- 현황
- 동탄역
- 자양하늘채베르
- 동탄2신도시
- 커트라인
- 제일풍경채
- 청약접수현황
- 입주자모집공고
- 힐스테이트광교중앙역퍼스트
- 네오
- 북서울자이폴라리스
- 송도자이더스타
- QM5
- 분양가
- 센트레빌아스테리움영등포
- e편한세상강일어반브릿지
- 금강펜테리움더시글로
- 송도자이크리스탈오션
- 당첨가점
- 영백홀
- 검단신도시
- Neo
- 일반공급
- 고덕강일
- 경쟁률
- 관악중앙하이츠포레
- 청약접수
- 트레이더스
- 특별공급
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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 |
글 보관함