Java学习者论坛

 找回密码
 立即注册

QQ登录

只需一步,快速开始

手机号码,快捷登录

恭喜Java学习者论坛(https://www.javaxxz.com)已经为数万Java学习者服务超过8年了!积累会员资料超过10000G+
成为本站VIP会员,下载本站10000G+会员资源,购买链接:点击进入购买VIP会员
JAVA高级面试进阶视频教程Java架构师系统进阶VIP课程

分布式高可用全栈开发微服务教程

Go语言视频零基础入门到精通

Java架构师3期(课件+源码)

Java开发全终端实战租房项目视频教程

SpringBoot2.X入门到高级使用教程

大数据培训第六期全套视频教程

深度学习(CNN RNN GAN)算法原理

Java亿级流量电商系统视频教程

互联网架构师视频教程

年薪50万Spark2.0从入门到精通

年薪50万!人工智能学习路线教程

年薪50万!大数据从入门到精通学习路线年薪50万!机器学习入门到精通视频教程
仿小米商城类app和小程序视频教程深度学习数据分析基础到实战最新黑马javaEE2.1就业课程从 0到JVM实战高手教程 MySQL入门到精通教程
查看: 458|回复: 0

[算法学习]一个用DES来加密、解密的类

[复制链接]
  • TA的每日心情
    开心
    2021-3-12 23:18
  • 签到天数: 2 天

    [LV.1]初来乍到

    发表于 2014-11-3 00:00:59 | 显示全部楼层 |阅读模式
    /*
      * 版权所有: 广州点讯科技有限公司 2003
      * Created on 2004-2-24 By Liudong
      */
      

      
      
    import java.security.*;
    import javax.crypto.Cipher;
    import javax.crypto.SecretKey;
    import javax.crypto.SecretKeyFactory;
    import javax.crypto.spec.DESKeySpec;

    /**
      * 字符串工具集合
      * @author Liudong
      */
    public class StringUtils {

    private static final String PASSWORD_CRYPT_KEY = "__jDlog_";
         private final static String DES = "DES";
      
      
       
       
         
       

       
       
      

    /**
      * 加密
      * @param src 数据源
      * @param key 密钥,长度必须是8的倍数
      * @return   返回加密后的数据
      * @throws Exception
      */
    public static byte[] encrypt(byte[] src, byte[] key)throws Exception {
                     //DES算法要求有一个可信任的随机数源
                     SecureRandom sr = new SecureRandom();
                     // 从原始密匙数据创建DESKeySpec对象
                     DESKeySpec dks = new DESKeySpec(key);
                     // 创建一个密匙工厂,然后用它把DESKeySpec转换成
                     // 一个SecretKey对象
                     SecretKeyFactory keyFactory = SecretKeyFactory.getInstance(DES);
                     SecretKey securekey = keyFactory.generateSecret(dks);
                     // Cipher对象实际完成加密操作
                     Cipher cipher = Cipher.getInstance(DES);
                     // 用密匙初始化Cipher对象
                     cipher.init(Cipher.ENCRYPT_MODE, securekey, sr);
                     // 现在,获取数据并加密
                     // 正式执行加密操作
                     return cipher.doFinal(src);
              }

              /**
               * 解密
               * @param src 数据源
               * @param key 密钥,长度必须是8的倍数
               * @return     返回解密后的原始数据
               * @throws Exception
               */
              public static byte[] decrypt(byte[] src, byte[] key)throws Exception {
                     // DES算法要求有一个可信任的随机数源
                     SecureRandom sr = new SecureRandom();
                     // 从原始密匙数据创建一个DESKeySpec对象
                     DESKeySpec dks = new DESKeySpec(key);
                     // 创建一个密匙工厂,然后用它把DESKeySpec对象转换成
                     // 一个SecretKey对象
                     SecretKeyFactory keyFactory = SecretKeyFactory.getInstance(DES);
                     SecretKey securekey = keyFactory.generateSecret(dks);
                     // Cipher对象实际完成解密操作
                     Cipher cipher = Cipher.getInstance(DES);
                     // 用密匙初始化Cipher对象
                     cipher.init(Cipher.DECRYPT_MODE, securekey, sr);
                     // 现在,获取数据并解密
                     // 正式执行解密操作
                     return cipher.doFinal(src);
              }
         /**
          * 密码解密
          * @param data
          * @return
          * @throws Exception
          */
         public final static String decrypt(String data){
              try {
                 return new String(decrypt(hex2byte(data.getBytes()),
                       PASSWORD_CRYPT_KEY.getBytes()));
             }catch(Exception e) {
             }
             return null;
         }
         /**
          * 密码加密
          * @param password
          * @return
          * @throws Exception
          */
         public final static String encrypt(String password){
             try {
                 return byte2hex(encrypt(password.getBytes(),PASSWORD_CRYPT_KEY.getBytes()));         }catch(Exception e) {
             }
             return null;
         }
    /**
      * 二行制转字符串
      * @param b
      * @return
      */
         public static String byte2hex(byte[] b) {
                     String hs = "";
                     String stmp = "";
                     for (int n = 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;
                     }
                     return hs.toUpperCase();
          }
          
         public static byte[] hex2byte(byte[] b) {
            if((b.length%2)!=0)
                   throw new IllegalArgumentException("长度不是偶数");
                     byte[] b2 = new byte[b.length/2];
                     for (int n = 0; n < b.length; n+=2) {
                         String item = new String(b,n,2);
                         b2[n/2] = (byte)Integer.parseInt(item,16);
                     }
            return b2;
         }

         public static void main(String[] args) {
             String pwd = "测试dasdfaaaaaaa";
             System.out.println("测试数据="+pwd);
             String data = encrypt(pwd);
             System.out.println("加密后的数据data="+data);
             pwd = decrypt(data);
             System.out.println("解密后="+pwd);
             
         }
    }
    运行结果:  

    D:java>java   StringUtils  
    测试数据=测试dasdfaaaaaaa  
    加密后的数据data=16FA9924D269C0BD98E5CE8AC23A42898311435A70E2DE90  
    解密后=测试dasdfaaaaaaa  

    D:java>  



    源码下载:http://file.javaxxz.com/2014/11/3/000059343.zip
    回复

    使用道具 举报

    您需要登录后才可以回帖 登录 | 立即注册

    本版积分规则

    QQ|手机版|Java学习者论坛 ( 声明:本站资料整理自互联网,用于Java学习者交流学习使用,对资料版权不负任何法律责任,若有侵权请及时联系客服屏蔽删除 )

    GMT+8, 2025-2-25 16:31 , Processed in 0.295616 second(s), 36 queries .

    Powered by Discuz! X3.4

    © 2001-2017 Comsenz Inc.

    快速回复 返回顶部 返回列表