首页数据库利用JAVA实现DES加密算法

利用JAVA实现DES加密算法

时间2024-02-28 20:24:03发布访客分类数据库浏览635
导读:收集整理的这篇文章主要介绍了利用JAVA实现DES加密算法,觉得挺不错的,现在分享给大家,也给大家做个参考。 DES加密介绍DES是一种对称加密算法,所谓对称加密算法即:加密和解密使用相...
收集整理的这篇文章主要介绍了利用JAVA实现DES加密算法,觉得挺不错的,现在分享给大家,也给大家做个参考。

DES加密介绍
DES是一种对称加密算法,所谓对称加密算法即:加密和解密使用相同密钥的算法。DES加密算法出自IBM的研究,后来被美国政府正式采用,之后开始广泛流传,但是近些年使用越来越少,因为DES使用56位密钥,以现代计算能力,24小时内即可被破解。虽然如此,在某些简单应用中,我们还是可以使用DES加密算法,本文简单讲解DES的JAVA实现。

JAVA实现
加密
代码有详细解释,不多废话。
注意:DES加密和解密过程中,密钥长度都必须是8的倍数
复制代码 代码如下:
        public byte[] desCrypto(byte[] datasource, String password) {            
                try{
                SecureRandom random = new SecureRandom();
                DESKeySPEc desKey = new DESKeySpec(password.getBytes());
                //创建一个密匙工厂,然后用它把DESKeySpec转换成
                SecretKeyFactory keyFactory = SecretKeyFactory.getInstance("DES");
                SecretKey securekey = keyFactory.generateSecret(desKey);
                //Cipher对象实际完成加密操作
                Cipher cipher = Cipher.getInstance("DES");
                //用密匙初始化Cipher对象
                cipher.inIT(Cipher.ENCRYPT_MODE, securekey, random);
                //现在,获取数据并加密
                //正式执行加密操作
                return cipher.doFinal(datasource);
                } catch(Throwable e){
                        e.PRintStackTrace();
                }
                return null;
        }

解密
代码有详细注释,不多废话
复制代码 代码如下:
        private byte[] decrypt(byte[] src, String password) throws Exception {
                // DES算法要求有一个可信任的随机数源
                SecureRandom random = new SecureRandom();
                // 创建一个DESKeySpec对象
                DESKeySpec desKey = new DESKeySpec(password.getBytes());
                // 创建一个密匙工厂
                SecretKeyFactory keyFactory = SecretKeyFactory.getInstance("DES");
                // 将DESKeySpec对象转换成SecretKey对象
                SecretKey securekey = keyFactory.generateSecret(desKey);
                // Cipher对象实际完成解密操作
                Cipher cipher = Cipher.getInstance("DES");
                // 用密匙初始化Cipher对象
                cipher.init(Cipher.DECRYPT_MODE, securekey, random);
                // 真正开始解密操作
                return cipher.doFinal(src);
        }

测试场景
例如,我们可以利用如上函数对字符串进行加密解密,也可以对文件进行加密解密,如:
复制代码 代码如下:
                //待加密内容
                String str = "测试内容";
                //密码,长度要是8的倍数
                String password = "12345678";
                byte[] result = DESCrypto.desCrypto(str.getBytes(),password);
                System.out.println("加密后内容为:"+new String(result));

                //直接将如上内容解密
                try {
                        byte[] decryResult = des.decrypt(result, password);
                        System.out.println("加密后内容为:"+new String(decryResult));
                } catch (Exception e1) {
                        e1.printStackTrace();
                }

您可能感兴趣的文章:
  • 分享Java常用几种加密算法(四种)
  • java自带的MessageDigest实现文本的md5加密算法
  • 使用java自带des加密算法实现文件加密和字符串加密
  • java实现MD5加密算法的实例代码
  • java实现的AES加密算法完整实例
  • java异或加密算法
  • RSA加密算法java简单实现方法(必看)
  • 详解Java中实现SHA1与MD5加密算法的基本方法
  • JAVA实现caesar凯撒加密算法
  • java实现同态加密算法的实例代码

声明:本文内容由网友自发贡献,本站不承担相应法律责任。对本内容有异议或投诉,请联系2913721942#qq.com核实处理,我们将尽快回复您,谢谢合作!


若转载请注明出处: 利用JAVA实现DES加密算法
本文地址: https://pptw.com/jishu/631901.html
SQL SERVER 2008 r2 数据压缩的两种方法第1/2页 如何在SQL Server 2008下轻松调试T-SQL语句和存储过程

游客 回复需填写必要信息