1. DES 暗号化と復号化
パッケージ com.itjh.javaUtil;import java.io.UnsupportedEncodingException;import java.security.InvalidKeyException;import java.security.NoSuchAlgorithmException;import java.security.SecureRandom;import java.security.spec.InvalidKeySpecException;import 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 July 3, 2014*/public class DESUtil {/** Security key*/private String keyData = "ABCDEFGHIJKLMNOPQRSTWXYZabcdefghijklmnopqrstwxyz0123456789-_.";/** * Function: Construction* * @author Song Lijun * @日付2014 年 7 月 3 日 */public DESUtil() {}/** * 関数: 構築* * @author Song Lijun* @date July 3, 2014* @param keyData * key */public DESUtil(String key) { this.keyData = key;}/** * 機能: 暗号化 (UTF-8) * * @author Song Lijun* @date July 3, 2014* @param source * ソース文字列 * @param charSet * エンコーディング * @return String * @throws UnsupportedEncodingException * エンコーディング例外 */public String encrypt(String source) throws UnsupportedEncodingException {return encrypt(source, "UTF-8");}/ * * * * 機能: 復号化 (UTF-8) * * @author Song Lijun* @date July 3, 2014* @param encryptedData * 暗号化された文字列 * @return String * @throws UnsupportedEncodingException * エンコード例外 */public String decrypt(String encryptedData)throws UnsupportedEncodingException {return decrypt(encryptedData, "UTF-8");}/** * 関数: 暗号化* * @著者 Song Lijun* @日付 2014 年 7 月 3 日* @param ソース *ソース文字列 * @param charSet * エンコーディング * @return String * @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 Song Lijun * @date July 3, 2014 * @param encryptedData * 暗号化された文字列 * @param charSet * エンコーディング * @return String * @throws UnsupportedEncodingException * エンコーディング例外 */public String decrypt(String encryptedData 、String charSet)throws 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 July 3, 2014*/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");} catch (NoSuchAlgorithmException e) {e.printStackTrace();} catch (NoSuchPaddingException e) {e.printStackTrace();}/** key で Cipher オブジェクトを初期化*/try {cipher.init(Cipher.ENCRYPT_MODE, key, sr);} catch (InvalidKeyException e) {e.printStackTrace();}/* *暗号化操作を正式に実行します*/byte encryptedData[] = null;try {encryptedData = cipher.doFinal(primaryData);} catch (IllegalStateException e) {e.printStackTrace();} catch (IllegalBlockSizeException e) {e.printStackTrace();} catch (BadPaddingException e) {e.printStackTrace();}/** 暗号化されたデータを返す*/return encryptedData;} /** * キーを使用してデータを復号化* * @param encryptedData * 暗号化されたデータ * @return byte[] * @author Song Lijun* @date July 3, 2014*/private byte[] descrypt(byte[] encryptedData) {/** 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();}/** key で 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();}復号化されたデータを返します;}/** *セキュリティ キーを取得するこの方法は、キーが生成されるたびに復号化と暗号化に使用されるキーが異なるため無効であり、これにより「最後のブロックが * 適切に埋め込まれていません」というエラーが発生します。 Lijun* @ date July 3, 2014*/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();rawKeyData を返す;}}
2. Base64暗号化と復号化
package com.itjh.javaUtil;import java.io.*;/** * Base64 エンコードとデコード。 * * @author Song Lijun* @date July 3, 2014*/public class Base64 {public Base64() {}/** * 関数: エンコードされた文字列* * @author Song Lijun* @date July 3, 2014* @param data * ソース文字列* @return String */public static String encode(String data) {return new String(encode(data.getBytes()));}/** * 関数: 文字列をデコードします* * @author Song Lijun* @date July 3, 2014* @param data * ソース文字列* @return String */public static String decode(String data) {return new String(decode(data .toCharArray( )));}/** * 関数: エンコーディング byte[] * * @author Song Lijun* @date July 3, 2014* @param data * source* @return char[] */public static char[] encode(byte[] data) {char[] out = new char[((data.length + 2) / 3) * 4];for (int i = 0,インデックス = 0; i < data.length; i += 3、インデックス += 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] = alphabet[(quad ? (val & 0x3F) : 64)];val >>= 6;out[index + 2] = alphabet[(trip ? (val & 0x3F) : 64)];val >>= 6;out[index + 1] = alphabet[val & 0x3F ];val >>= 6;out[index + 0] = alphabet[val & 0x3F];}return out;}/** * 関数: デコード* * @author Song Lijun* @date July 3, 2014* @param data * エンコードされた文字配列* @return byte[] */public static byte[] decode(char[] data) {int tempLen = data.length;for ( int ix = 0; ix < data.length; ix++) {if ((data[ix] > 255) || コード[data[ix]] < 0) {--tempLen; // 無効な文字とパディングを無視する}}// 必要な長さを計算します:// -- 有効な Base64 文字 4 つごとに 3 バイト// -- 余分な Base64 文字が 3 つある場合はさらに 2 バイト、/ / または 2 つの extra.int がある場合は 1 バイトを追加します。 len = (tempLen / 4) * 3;if ((tempLen % 4) == 3) {len += 2;}if ((tempLen % 4) == 2) {len += 1;}byte[] out = new byte[len];int shft = 0; // accumint に格納される余分なビットの数 = 0; // 余分なビットsint index = 0;// 次に、配列全体を調べます ('tempLen' 値は使用しません)for (int ix = 0; ix < data.length; ix++) {int value = (data[ix] > 255) ? -1 : code[data[ix]];if (value >= 0) { // 非 codeaccum <<= 6 をスキップします。 // スラッシュシフトのたびにビットが 6 ずつシフトアップされます。 += 6; // 新しいビットが inaccum |= 値としてループされます。 // (shift >= 8) { // 8 つ以上がシフトされるときは常に、shift -= 8;それらを書き出します(から上部を残し、anyout[index++] = // 次の反復のために下部に余分な部分を残します。(byte) ((accum >> shift) & 0xff);}}}// まだ何か間違っている場合は、ただ吐き出さなければなりませんnow!if (index != out.length) {throw new Error("データ長の計算が間違っています (" + out.length + " の代わりに " +index+ " を書きました)");}return out;}/** *関数: ファイルをエンコード* * @author Song Lijun* @date July 3, 2014* @param file * ソース ファイル*/public static void encode(File file) throws IOException {if (!file.exists()) {システム終了(0);}else {byte[] デコード = readBytes(ファイル);char[] エンコード = encode(デコード);writeChars(ファイル、エンコード);}ファイル = null;}/** * 機能: ファイルをデコードします。 * * @author Song Lijun* @date July 3, 2014* @param file * ソース ファイル* @throws IOException */public static void decode(File file) throws IOException {if (!file.exists()) {システム終了(0);} else {char[] エンコード = readChars(file);byte[] デコード = decode(エンコード);writeBytes(file,デコードされた);}file = null;}//// 値 0..63 のコード文字//private static char[] alphabet = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=".toCharArray();//// 変換用のルックアップ テーブルBase64 文字を範囲内の値に変換0..63//private static byte[] code = new byte[256];static {for (int i = 0; i < 256; i++) {codes[i] = -1;// LoggerUtil.debug(i + "&" + code[i] + " ");}for (int i = 'A'; i <= 'Z'; i++) {codes[i] = (byte) (i - 'A');// LoggerUtil.debug(i + "&" + codes[i] + " ");}for (int i = 'a'; i <= 'z'; i++) {codes[i] = (バイト) (26 + i - 'a');// LoggerUtil.debug(i + "&" + codes[i] + " ");}for (int i = '0'; i <= '9 '; i++) {codes[i] = (バイト) (52 + i - '0');// LoggerUtil.debug(i + "&" + codes[i] + " ");}codes['+'] = 62; code['/'] = 63;}private static byte[] readBytes(File file) throws 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 byte[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 (Exception e) {System.out.println(e);}}return b;}private static char[] readChars(File file) throws 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);}}} 最後に {try {if (caw != null)caw.close();if (in != null)in.close();if (fr != null)fr.close();} catch (Exception e) {System.out.println(e);}}return caw.toCharArray();}private static void writeBytes(File file, byte[] data) throws IOException {OutputStream fos = null;OutputStream os = null;try {fos = new FileOutputStream(file);os = new BufferedOutputStream(fos);os.write(data);}finally {try {if ( os != null)os.close();if (fos != null)fos.close();} catch (例外 e) {System.out.println(e);}}}private static void writeChars(File file, char[] data) throws IOException {Writer fos = null;Writer os = null;try {fos = new FileWriter(file);os = new BufferedWriter(fos);os.write(data);}finally {try {if (os != null)os.close();if (fos != null)fos.close();} catch (例外 e) {e.printStackTrace();}}}// //////////////////////// / ///////////////////////////// テストコードの終わり。// //////////////////////////////////////////////// ///}
PS: 暗号化技術に関しては、このサイトでは参考として次の暗号化ツールも提供しています。
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