1. DES 암호화 및 복호화
패키지 com.itjh.javaUtil;가져오기 java.io.UnsupportedEncodingException;가져오기 java.security.InvalidKeyException;가져오기 java.security.NoSuchAlgorithmException;가져오기 java.security.SecureRandom;가져오기 java.security.spec.InvalidKeySpecException;가져오기 javax.crypto.BadPaddingException ;가져오기 javax.crypto.Cipher;가져오기 javax.crypto.IllegalBlockSizeException;import javax.crypto.KeyGenerator;import javax.crypto.NoSuchPaddingException;import javax.crypto.SecretKey;import javax.crypto.SecretKeyFactory;import javax.crypto.spec.DESKeySpec;/** * DES 암호화 및 해독합니다. * * @author Song Lijun* @date 2014년 7월 3일*/public class DESUtil {/** 보안 키*/private String keyData = "ABCDEFGHIJKLMNOPQRSTWXYZabcdefghijklmnopqrstwxyz0123456789-_.";/** * 기능: 구성* * @author Song Lijun * @날짜 2014년 7월 3일 */public DESUtil() {}/** * 함수: 건설* * @author Song Lijun* @date 2014년 7월 3일* @param keyData * key */public DESUtil(String key) { this.keyData = key;}/** * 기능: 암호화(UTF-8) * * @author Song Lijun* @date 2014년 7월 3일* @param 소스 * 소스 문자열 * @param charSet * 인코딩 * @return 문자열 * @throws UnsupportedEncodingException * 인코딩 예외 */public String encrypt(String source) throws UnsupportedEncodingException {return encrypt(source, "UTF-8");}/ * * * * 기능: 복호화(UTF-8) * * @author Song Lijun* @date 2014년 7월 3일* @param cryptoData * 암호화된 문자열 * @return String * @throws UnsupportedEncodingException * 인코딩 예외 */public String decrypt(String 암호화된Data)throws UnsupportedEncodingException {return decrypt(encryptedData, "UTF-8");}/** * 함수: 암호화* * @author 송리준* @date 2014년 7월 3일* @param 출처 * 소스 문자열 * @param charSet * 인코딩 * @return 문자열 * @throws UnsupportedEncodingException * 인코딩 예외 */public String encrypt(String source, String charSet)throws UnsupportedEncodingException {String encrypt = null;byte[] ret = encrypt(source.getBytes ( charSet));encrypt = new String(Base64.encode(ret));return encrypt;}/** * * 기능: 복호화 * * @author 송리준 * @date 2014년 7월 3일 * @param 암호화된 데이터 * 암호화된 문자열 * @param charSet * 인코딩 * @return 문자열 * @throws UnsupportedEncodingException * 인코딩 예외 */public String decrypt(String 암호화된 데이터 , String charSet)은 UnsupportedEncodingException을 발생시킵니다. {String descryptedData = null;byte[] ret = descrypt(Base64.decode(encryptedData.toCharArray()));descryptedData = new String(ret, charSet);return descryptedData;}/** * 암호화된 데이터는 생성된 키를 사용하여 원본 데이터를 암호화합니다. * * @param PrimaryData * 원본 데이터 * @return byte[] * @author Song Lijun* @date 2014년 7월 3일*/private byte[] encrypt(byte[]primaryData) {/** 보안 키 가져오기*/byte rawKeyData[] = getKey();/** DES 알고리즘에는 신뢰할 수 있는 난수 소스가 필요합니다*/SecureRandom sr = new SecureRandom () ;/** 원래 키 데이터를 사용하여 DESKeySpec 객체 생성*/DESKeySpec dks = null;try {dks = new DESKeySpec(keyData.getBytes());} catch (InvalidKeyException e) {e.printStackTrace();}/** 키 팩토리 생성*/SecretKeyFactory keyFactory = null;try {keyFactory = SecretKeyFactory.getInstance("DES");} catch (NoSuchAlgorithmException e) {e.printStackTrace ( );}/** 키 팩토리를 사용하여 DESKeySpec을 SecretKey 객체로 변환*/SecretKey key = null;try {key = keyFactory.generateSecret(dks);} catch (InvalidKeySpecException e) {e.printStackTrace();}/** Cipher 객체는 실제로 암호화 작업을 완료합니다*/Cipher cipher = null;try {cipher = Cipher .getInstance ("DES");} 잡기(NoSuchAlgorithmException e) {e.printStackTrace();} 잡기(NoSuchPaddingException e) {e.printStackTrace();}/** 키를 사용하여 Cipher 객체 초기화*/try {cipher.init(Cipher.ENCRYPT_MODE, key, sr);} catch (InvalidKeyException e) {e.printStackTrace();}/* * 암호화 작업을 공식적으로 수행*/byte cryptoData[] = null;try {encryptedData = cipher.doFinal(primaryData);} catch (IllegalStateException e) {e.printStackTrace();} catch (IllegalBlockSizeException e) {e.printStackTrace();} catch (BadPaddingException e) {e.printStackTrace();}/** 암호화된 데이터 반환*/return 암호화된 데이터;} /** * 키를 사용하여 데이터 암호 해독* * @param cryptoData * 암호화된 데이터 * @return byte[] * @author Song Lijun* @date 2014년 7월 3일*/private byte[] descrypt(byte[] 암호화된Data) {/** DES 알고리즘에는 신뢰할 수 있는 난수 소스가 필요합니다*/SecureRandom sr = new SecureRandom();/* * 가져오기 보안 키 */byte rawKeyData[] = getKey();/** 원시 키 데이터를 사용하여 DESKeySpec 객체 생성 */DESKeySpec dks = null; {dks = new DESKeySpec(keyData.getBytes());} catch (InvalidKeyException e) {e.printStackTrace();}/** 키 팩토리 생성*/SecretKeyFactory keyFactory = null;try {keyFactory = SecretKeyFactory.getInstance( " DES");} catch (NoSuchAlgorithmException e) {e.printStackTrace();}/** 키 팩토리를 사용하여 DESKeySpec을 SecretKey 객체로 변환 */SecretKey key = null;try {key = keyFactory.generateSecret(dks);} catch (InvalidKeySpecException e) {e.printStackTrace();}/** Cipher 객체는 실제로 완료된 암호화 작업*/Cipher cipher = null;try {cipher = Cipher.getInstance("DES");} catch(NoSuchAlgorithmException e) {e.printStackTrace();} catch (NoSuchPaddingException e) {e.printStackTrace();}/** 키를 사용하여 Cipher 객체 초기화*/try {cipher.init(Cipher.DECRYPT_MODE, key, sr);} catch (InvalidKeyException e) {e.printStackTrace();}/** 복호화 작업의 정식 실행*/byte decryptedData[] = null;try {decryptedData = cipher.doFinal(encryptedData);} catch(IllegalStateException e) {e.printStackTrace();} catch(IllegalBlockSizeException e) {e.printStackTrace();} catch(BadPaddingException e) {e.printStackTrace();} return decryptedData;}/** * 보안 키를 얻는 이 방법은 키가 생성될 때마다 복호화와 암호화에 사용되는 키가 다르기 때문에 유효하지 않습니다. 이로 인해 Give final block not *괜찮게 패딩되지 않음 * * @return 바이트 배열* @author Song이 발생합니다. Lijun* @ 날짜 2014년 7월 3일*/private byte[] getKey() {/** DES 알고리즘에는 신뢰할 수 있는 난수 소스가 필요합니다*/SecureRandom sr = new SecureRandom();/** 선택한 DES 알고리즘에 대한 키 생성기 객체 생성 */KeyGenerator kg = null;try {kg = KeyGenerator.getInstance("DES");} catch (NoSuchAlgorithmException e) {e.printStackTrace();}kg.init ( sr);/** 키 도구 클래스 생성*/SecretKey key = kg.generateKey();/** 키 바이트 배열 생성*/byte rawKeyData[] = key.getEncoded();return rawKeyData;}}
2. Base64 암호화 및 복호화
package com.itjh.javaUtil;import java.io.*;/** * Base64 인코딩 및 디코딩. * * @author Song Lijun* @date 2014년 7월 3일*/public class Base64 {public Base64() {}/** * 함수: 인코딩된 문자열* * @author Song Lijun* @date 2014년 7월 3일* @param data * 소스 문자열* @return String */public static String encode(String data) {return new String(encode(data.getBytes()));}/** * 함수: 문자열 디코딩* * @author Song Lijun* @date 2014년 7월 3일* @param data * source string* @return String */public static String decode(String data) {return new String(decode(data .toCharArray( )));}/** * 기능: 인코딩 byte[] * * @author Song Lijun* @date 2014년 7월 3일* @param data * 소스* @return char[] */public static char[] encode(byte[] data) {char[] out = new char[((data.length + 2) / 3) * 4];for (int i = 0, index = 0; i < data.length; i += 3, index += 4) {부울 쿼드 = false; 부울 트립 = false;int val = (0xFF & (int) data[i]);val <<= 8;if ((i + 1) < data.length) {val |= (0xFF & (int) data[i + 1]);trip = true;}val <<= 8;if ((i + 2) < data.length) {val |= (0xFF & (int) data[i + 2]);quad = true;}out[index + 3] = 알파벳[(quad ? (val & 0x3F) : 64)];val >>= 6;out[index + 2] = 알파벳[(trip ? (val & 0x3F) : 64)];val >>= 6;out[index + 1] = 알파벳[val & 0x3F ];val >>= 6;out[index + 0] = 알파벳[val & 0x3F];}return out;}/** * 기능: 디코딩* * @author 송 리준* @date 2014년 7월 3일* @param data * 인코딩된 문자 배열* @return byte[] */public static byte[] decode(char[] data) {int tempLen = data.length;for ( int ix = 0; ix < 데이터.길이; ix++) {if ((데이터[ix] > 255) || 코드[데이터[ix]] < 0) {--tempLen; // 유효하지 않은 문자 및 패딩 무시}}// 필요한 길이 계산:// -- 유효한 base64 문자 4개당 3바이트// -- 추가 base64 문자 3개가 있는 경우 2바이트 추가,/ / 또는 2개가 있는 경우 1바이트 더하기 extra.int len = (tempLen / 4) * 3;if ((tempLen % 4) == 3) {len += 2;}if ((tempLen % 4) == 2) {len += 1;}byte[] out = new byte[len];int shift = 0; // accumint에 저장된 초과 비트 수 = 0; // 초과 비트int 인덱스 = 0;// 이제 전체 배열을 살펴봅니다('tempLen' 값을 사용하지 않음)for (int ix = 0; ix < data.length; ix++) {int value = (data[ix] > 255) ? -1 :codes[data[ix]];if (value >= 0) { // 비 codeaccum 건너뛰기 <<= 6 // thrushift마다 비트가 6씩 위로 이동합니다. += 6; // 새로운 비트가 삽입되는 루프 |= value; // 하단에.if (shift >= 8) { // 8개 이상이 이동될 때마다,shift -= 8; 그것들을 써내려 가세요 (from 상단, anyout[index++] = // 다음 반복을 위해 하단에 초과분을 남겨둡니다.(byte) ((accum >> Shift) & 0xff);}}}// 여전히 잘못된 것이 있으면 그냥 던져야 합니다. now!if (index != out.length) {throw new Error("잘못 계산된 데이터 길이(" + out.length + " 대신 " + index+ "를 썼습니다)");}return out;}/** * 함수: 파일 인코딩* * @author Song Lijun* @date 2014년 7월 3일* @param 파일 * 소스 파일*/public static void encode(파일 파일) throws IOException {if (!file.exists()) {System.exit (0);}else {byte[] decoded = readBytes(파일);char[] 인코딩 = encode(디코딩);writeChars(파일, 인코딩);}file = null;}/** * 기능: 파일을 디코딩합니다. * * @author Song Lijun* @date 2014년 7월 3일* @param file * 소스 파일* @throws IOException */public static void decode(File file) throws IOException {if (!file.exists()) {System.exit (0);} else {char[] 인코딩 = readChars(파일);byte[] 디코딩 = 디코딩(인코딩);writeBytes(파일, decoded);}file = null;}//// 값의 코드 문자 0..63//private static char[] 알파벳 = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=".toCharArray();//// 변환을 위한 조회 테이블 base64 문자를 범위 내 값으로 0..63//개인 정적 바이트[] 코드 = 새 바이트[256];static {for (int i = 0; i < 256; i++) {codes[i] = -1;// LoggerUtil.debug(i + "&" + 코드[i] + " ");}for (int i = 'A'; i <= 'Z'; i++) {codes[i] = (바이트) (i - 'A');// LoggerUtil.debug(i + "&" + 코드[i] + " ");}for (int i = 'a'; i <= 'z'; i++) {codes[i] = (바이트) (26 + i - 'a');// LoggerUtil.debug(i + "&" + 코드[i] + " ");}for (int i = '0'; i <= '9 '; 나는 ++) {codes[i] = (바이트) (52 + i - '0');// LoggerUtil.debug(i + "&" + 코드[i] + " ");}codes['+'] = 62; 코드['/'] = 63;}private static byte[] readBytes(파일 파일)에서 IOException이 발생합니다. {ByteArrayOutputStream baos = new ByteArrayOutputStream();byte[] b = null;InputStream fis = null;InputStream is = null;try {fis = new FileInputStream(file);is = new BufferedInputStream(fis);int count = 0;byte[] buf = new 바이트[16384];while ((count = is.read(buf)) != -1) {if (count > 0) {baos.write(buf, 0, count);}}b = baos.toByteArray();} 마지막으로 {try {if (fis != null)fis.close();if (is != null)is.close ();if (baos != null)baos.close();} catch (예외 e) {System.out.println(e);}}return b;}private static char[] readChars(파일 파일)는 IOException을 발생시킵니다. {CharArrayWriter caw = new CharArrayWriter();Reader fr = null;Reader in = null;try {fr = new FileReader(file);in = new BufferedReader(fr);int count = 0;char [] buf = new char[16384];while ((count = in.read(buf)) != -1) {if (count > 0) {caw.write(buf, 0, count);}}} 마지막으로 {if (caw != null)caw.close();if (in != null)in.close();if (fr != null)fr.close();} catch(예외 e) {System.out.println(e);}}return caw.toCharArray();}private static void writeBytes(파일 파일, byte[] 데이터)는 IOException을 발생시킵니다. {OutputStream fos = null;OutputStream os = null;try {fos = new FileOutputStream(file);os = new BufferedOutputStream(fos);os.write(data);} 마지막으로 {try {if ( os != null)os.close();if (fos != null)fos.close();} catch (예외 e) {System.out.println(e);}}}private static void writeChars(파일 파일, char[] 데이터)가 IOException을 발생시킵니다. {Writer fos = null;Writer os = null;try {fos = new FileWriter(file);os = new BufferedWriter(fos);os.write(data);} 마지막으로 {try {if (os != null)os.close();if (fos != null)fos.close();} catch(예외 e) {e.printStackTrace();}}}// ///////////////////////// / ////////////////////////////// 테스트 코드 끝.// ///////////////////////////////////////////////// ///}
추신: 암호화 기술과 관련하여 이 사이트는 참고용으로 다음 암호화 도구도 제공합니다.
BASE64 인코딩 및 디코딩 도구: http://tools.VeVB.COm/transcoding/base64
MD5 온라인 암호화 도구: http://tools.VeVB.COm/password/CreateMD5Password
이스케이프 암호화/복호화 도구: http://tools.VeVB.COm/password/escapepwd
온라인 SHA1 암호화 도구: http://tools.VeVB.COm/password/sha1encode
단축 링크(단축 URL) 온라인 생성 도구: http://tools.VeVB.COm/password/dwzcreate
짧은 링크(짧은 URL) 온라인 복원 도구: http://tools.VeVB.COm/password/unshorturl
강력한 비밀번호 생성기: http://tools.VeVB.COm/password/CreateStrongPassword