标签:
| 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 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 | importjava.security.*;importjavax.crypto.Cipher;importjavax.crypto.SecretKey;importjavax.crypto.SecretKeyFactory;importjavax.crypto.spec.DESKeySpec;/** * Copyright 2007 GuangZhou Cotel Co. Ltd. * All right reserved.    * DES加密解密类.     * @author <a href="mailto:xiexingxing1121@126.com" mce_href="mailto:xiexingxing1121@126.com">AmigoXie</a> * @version 1.0 * Creation date: 2007-7-31 - 上午11:59:28 */publicclassDes {    /** 加密、解密key. */    privatestaticfinalString PASSWORD_CRYPT_KEY = "kEHrDooxWHCWtfeSxvDvgqZq";    /** 加密算法,可用 DES,DESede,Blowfish. */    privatefinalstaticString ALGORITHM = "DES";    publicstaticvoidmain(String[] args) throwsException {        String md5Password = "202cb962ac59075b964b07152d234b70";        String str = Des.encrypt(md5Password);        System.out.println("str: "+ str);        str = Des.decrypt(str);        System.out.println("str: "+ str);    }        /**     * 对数据进行DES加密.     * @param data 待进行DES加密的数据     * @return 返回经过DES加密后的数据     * @throws Exception     * @author <a href="mailto:xiexingxing1121@126.com" mce_href="mailto:xiexingxing1121@126.com">AmigoXie</a>     * Creation date: 2007-7-31 - 下午12:06:24     */    publicfinalstaticString decrypt(String data) throwsException {        returnnewString(decrypt(hex2byte(data.getBytes()),                PASSWORD_CRYPT_KEY.getBytes()));    }    /**     * 对用DES加密过的数据进行解密.     * @param data DES加密数据     * @return 返回解密后的数据     * @throws Exception     * @author <a href="mailto:xiexingxing1121@126.com" mce_href="mailto:xiexingxing1121@126.com">AmigoXie</a>     * Creation date: 2007-7-31 - 下午12:07:54     */    publicfinalstaticString encrypt(String data) throwsException  {        returnbyte2hex(encrypt(data.getBytes(), PASSWORD_CRYPT_KEY                .getBytes()));    }        /**     * 用指定的key对数据进行DES加密.     * @param data 待加密的数据     * @param key DES加密的key     * @return 返回DES加密后的数据     * @throws Exception     * @author <a href="mailto:xiexingxing1121@126.com" mce_href="mailto:xiexingxing1121@126.com">AmigoXie</a>     * Creation date: 2007-7-31 - 下午12:09:03     */    privatestaticbyte[] encrypt(byte[] data, byte[] key) throwsException {        // DES算法要求有一个可信任的随机数源        SecureRandom sr = newSecureRandom();        // 从原始密匙数据创建DESKeySpec对象        DESKeySpec dks = newDESKeySpec(key);        // 创建一个密匙工厂,然后用它把DESKeySpec转换成        // 一个SecretKey对象        SecretKeyFactory keyFactory = SecretKeyFactory.getInstance(ALGORITHM);        SecretKey securekey = keyFactory.generateSecret(dks);        // Cipher对象实际完成加密操作        Cipher cipher = Cipher.getInstance(ALGORITHM);        // 用密匙初始化Cipher对象        cipher.init(Cipher.ENCRYPT_MODE, securekey, sr);        // 现在,获取数据并加密        // 正式执行加密操作        returncipher.doFinal(data);    }    /**     * 用指定的key对数据进行DES解密.     * @param data 待解密的数据     * @param key DES解密的key     * @return 返回DES解密后的数据     * @throws Exception     * @author <a href="mailto:xiexingxing1121@126.com" mce_href="mailto:xiexingxing1121@126.com">AmigoXie</a>     * Creation date: 2007-7-31 - 下午12:10:34     */    privatestaticbyte[] decrypt(byte[] data, byte[] key) throwsException {        // DES算法要求有一个可信任的随机数源        SecureRandom sr = newSecureRandom();        // 从原始密匙数据创建一个DESKeySpec对象        DESKeySpec dks = newDESKeySpec(key);        // 创建一个密匙工厂,然后用它把DESKeySpec对象转换成        // 一个SecretKey对象        SecretKeyFactory keyFactory = SecretKeyFactory.getInstance(ALGORITHM);        SecretKey securekey = keyFactory.generateSecret(dks);        // Cipher对象实际完成解密操作        Cipher cipher = Cipher.getInstance(ALGORITHM);        // 用密匙初始化Cipher对象        cipher.init(Cipher.DECRYPT_MODE, securekey, sr);        // 现在,获取数据并解密        // 正式执行解密操作        returncipher.doFinal(data);    }    publicstaticbyte[] hex2byte(byte[] b) {        if((b.length % 2) != 0)            thrownewIllegalArgumentException("长度不是偶数");        byte[] b2 = newbyte[b.length / 2];        for(intn = 0; n < b.length; n += 2) {            String item = newString(b, n, 2);            b2[n / 2] = (byte) Integer.parseInt(item, 16);        }        returnb2;    }    publicstaticString byte2hex(byte[] b) {        String hs = "";        String stmp = "";        for(intn = 0; n < b.length; n++) {            stmp = (java.lang.Integer.toHexString(b[n] & 0XFF));            if(stmp.length() == 1)                hs = hs + "0"+ stmp;            else                hs = hs + stmp;        }        returnhs.toUpperCase();    }} | 
标签:
原文地址:http://www.cnblogs.com/mengfanxiao/p/4479457.html