本文主要是介绍3DES加解密案例,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
在CBC(不光是DES算法)模式下,iv通过随机数(或伪随机)机制产生是一种比较常见的方法。iv的作用主要是用于产生密文的第一个block,以使最终生成的密文产生差异(明文相同的情况下),使密码攻击变得更为困难,除此之外iv并无其它用途。
最大的好处是,可以令到即使相同的明文,相同的密钥,能产生不同的密文。
例如,我们用DES方式在数据保存用户密码的时候,可以另外增加一列,把向量同时保存下来,并且每次用不同的向量。这样的好处是,即使两个用户的密码是一样的,数据库保存的密文,也会不一样,就能降低猜测的可能性。
import sun.misc.BASE64Encoder;import javax.crypto.Cipher;
import javax.crypto.SecretKeyFactory;
import javax.crypto.spec.DESedeKeySpec;
import javax.crypto.spec.IvParameterSpec;
import java.security.Key;public class TriDESUtil {public static void main(String[] args) throws Exception {byte[] key = "1234567890AB1234567890AB".getBytes();byte[] keyiv = "20160612".getBytes();byte[] data="{\"phoneNo\":\"123ABC\"}".getBytes("gb2312");byte[] str1 = des3EncodeCBC(key, keyiv, data);byte[] str2 = des3DecodeCBC(key, keyiv, str1);System.out.println(new BASE64Encoder().encode(str1));System.out.println(new String(str2, "gb2312"));}/*** CBC加密* @param key 密钥* @param keyiv IV* @param data 明文* @return Base64编码的密文* @throws Exception*/public static byte[] des3EncodeCBC(byte[] key, byte[] keyiv, byte[] data)throws Exception {Key deskey = null;DESedeKeySpec spec = new DESedeKeySpec(key);SecretKeyFactory keyfactory = SecretKeyFactory.getInstance("DESede");deskey = keyfactory.generateSecret(spec);Cipher cipher = Cipher.getInstance("desede" + "/CBC/PKCS5Padding");IvParameterSpec ips = new IvParameterSpec(keyiv);cipher.init(Cipher.ENCRYPT_MODE, deskey, ips);byte[] bOut = cipher.doFinal(data);return bOut;}/*** CBC解密* @param key 密钥* @param keyiv IV* @param data Base64编码的密文* @return 明文* @throws Exception*/public static byte[] des3DecodeCBC(byte[] key, byte[] keyiv, byte[] data)throws Exception {Key deskey = null;DESedeKeySpec spec = new DESedeKeySpec(key);SecretKeyFactory keyfactory = SecretKeyFactory.getInstance("desede");deskey = keyfactory.generateSecret(spec);Cipher cipher = Cipher.getInstance("desede" + "/CBC/PKCS5Padding");IvParameterSpec ips = new IvParameterSpec(keyiv);cipher.init(Cipher.DECRYPT_MODE, deskey, ips);byte[] bOut = cipher.doFinal(data);return bOut;}
}
这篇关于3DES加解密案例的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!