主页 > 知识库 > 利用JAVA实现DES加密算法

利用JAVA实现DES加密算法

热门标签:南京外呼系统租用 宁夏外呼系统方案 智能语音外呼系统打电话 怎样在地图标注自己的信息 电销外呼系统违规 济南电销外呼防封卡怎么样 高德地图标注生成 400电话怎么申请收费标准 400电话办理2273649Z空间

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实现同态加密算法的实例代码

标签:惠州 仙桃 唐山 茂名 平顶山 潜江 贵港 长白山

巨人网络通讯声明:本文标题《利用JAVA实现DES加密算法》,本文关键词  利用,JAVA,实现,DES,加密,;如发现本文内容存在版权问题,烦请提供相关信息告之我们,我们将及时沟通与处理。本站内容系统采集于网络,涉及言论、版权与本站无关。
  • 相关文章
  • 下面列出与本文章《利用JAVA实现DES加密算法》相关的同类信息!
  • 本页收集关于利用JAVA实现DES加密算法的相关信息资讯供网民参考!
  • 推荐文章