Java 通用的DES加密工具类的实现
2015-11-23 14:12
531 查看
由于:java端对 DES加密算法默认的死EBC所以我们要手动的把其转化为CBC
保持一致的因素有三个
:1.密钥 (kingsfykj) 2.偏移量 (IV) 3.输入
保持一致的因素有三个
:1.密钥 (kingsfykj) 2.偏移量 (IV) 3.输入
import sun.misc.BASE64Encoder; import sun.misc.BASE64Decoder; import javax.crypto.*; import javax.crypto.spec.DESKeySpec; import javax.crypto.spec.IvParameterSpec; import java.security.Key; import java.security.spec.AlgorithmParameterSpec; /** * 使用DES加密和解密的方法 * * @修改者 小老虎2 * @author:azhong * @change:exmorning * */ public class CryptoTools { private final byte[] DESkey = "kingfykj".getBytes("UTF-8");// 设置密钥,略去 private final byte[] DESIV = {0x12, 0x34, 0x56, 0x78, (byte) 0x90, (byte) 0xAB, (byte) 0xCD, (byte) 0xEF};// 设置向量,略去 private AlgorithmParameterSpec iv = null;// 加密算法的参数接口,IvParameterSpec是它的一个实现 private Key key = null; public CryptoTools() throws Exception { DESKeySpec keySpec = new DESKeySpec(DESkey);// 设置密钥参数 iv = new IvParameterSpec(DESIV);// 设置向量 SecretKeyFactory keyFactory = SecretKeyFactory.getInstance("DES");// 获得密钥工厂 key = keyFactory.generateSecret(keySpec);// 得到密钥对象 } public String encode(String data) throws Exception { Cipher enCipher = Cipher.getInstance("DES/CBC/PKCS5Padding");// 得到加密对象Cipher enCipher.init(Cipher.ENCRYPT_MODE, key, iv);// 设置工作模式为加密模式,给出密钥和向量 byte[] pasByte = enCipher.doFinal(data.getBytes("utf-8")); BASE64Encoder base64Encoder = new BASE64Encoder(); return base64Encoder.encode(pasByte); } public String decode(String data) throws Exception { Cipher deCipher = Cipher.getInstance("DES/CBC/PKCS5Padding"); deCipher.init(Cipher.DECRYPT_MODE, key, iv); BASE64Decoder base64Decoder = new BASE64Decoder(); byte[] pasByte = deCipher.doFinal(base64Decoder.decodeBuffer(data)); return new String(pasByte, "UTF-8"); } public static void main(String[] args) { try { String test = "aaaaaa"; CryptoTools des = new CryptoTools();//自定义密钥 System.out.println("加密前的字符:"+test); System.out.println("加密后的字符:"+des.encode(test)); System.out.println("解密后的字符:"+des.decode(des.encode(test))); } catch (Exception e) { e.printStackTrace(); } } }
相关文章推荐
- java基本知识(二)
- spring框架学习(六)AOP
- spring框架学习(五)注解
- Java - 多线程
- spring框架学习(四)自动装配
- Eclipse安装SVN插件教程
- spring框架学习(三)junit单元测试
- spring框架学习(二)依赖注入
- Java的文件读写操作
- spring框架学习(一)
- JAVA 3DES加密解密
- Java - 文件(IO流)
- Mac 环境下配置opencv(Eclipse)
- jar命令成功完成 java -jar 命令却提示“没有主清单属性”!
- Java - 注解 (Annotation)
- Java 反射
- Java中thread的join方法
- Java - 泛型 ( Generic )
- Java数据类型和MySql数据类型对应表
- Spring4 IOC详解