欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页

JAVA 实现DES MD5加密

程序员文章站 2024-03-20 14:16:10
...
package com.esailcar.finance.shenzhou.utils;

import java.io.UnsupportedEncodingException;
import java.security.MessageDigest;
import java.security.NoSuchAlgorithmException;
import java.security.SecureRandom;

import javax.crypto.Cipher;
import javax.crypto.SecretKey;
import javax.crypto.SecretKeyFactory;
import javax.crypto.spec.DESKeySpec;

import sun.misc.BASE64Decoder;
import sun.misc.BASE64Encoder;

public class SecretDigest {
        
        private final static String MD5="MD5";
        private final static String DES="DES";
        private final static String ENCODE="UTF-8";
        private final static String KEY="asdf1234";
        
        //MD5加密
        public static String encodeByMD5(String str) throws NoSuchAlgorithmException, UnsupportedEncodingException
        {
            MessageDigest md5=MessageDigest.getInstance(MD5);
            StringBuffer md5buffer=new StringBuffer();
            md5.update(str.getBytes("UTF-8"));
            byte[] md5bytes=md5.digest();
            String hexString=null;
            for(byte md5byte : md5bytes)
            {
                 hexString=Integer.toHexString(0xff&md5byte);
                if(hexString.length()==1)
                {
                    md5buffer.append("0").append(hexString);
                }
                else
                {
                    md5buffer.append(hexString);
                }
            }
            return md5buffer.toString();        
        }
        
        /**
         * DES加密
         * @param str
         * @return
         * @throws Exception
         */
        public static String encodeByDES(String str)throws Exception
        {
            byte[] data=str.getBytes(ENCODE);
            
            byte[] key=KEY.getBytes(ENCODE);
           
            SecureRandom sr = new SecureRandom();
            // 通过key创建DESKeySpec对象
            DESKeySpec dks = new DESKeySpec(key);
            
            // 创建SecretKeyFactory,把DESKeySpec转换成SecretKey对象
            SecretKeyFactory keyFactory = SecretKeyFactory.getInstance(DES);
            SecretKey securekey = keyFactory.generateSecret(dks);

            // Cipher对象实际完成加密操作
            Cipher cipher = Cipher.getInstance(DES);

            // 用securekey初始化Cipher对象
            cipher.init(Cipher.ENCRYPT_MODE, securekey, sr);
            
            //BASE64编码
            String message=new BASE64Encoder().encode(cipher.doFinal(data));
            return message;            
        }
        /**
         * DES解密
         * @param str
         * @return
         * @throws Exception
         */
        public static String decodeByDES(String str)throws Exception
        {
              if (str == null)
                    return null;
           //BASE64解码
           BASE64Decoder decoder = new BASE64Decoder();
            
            byte[] data=decoder.decodeBuffer(str);
            byte[] key=KEY.getBytes(ENCODE);
            SecureRandom sr = new SecureRandom();
            // 通过key创建DESKeySpec对象
            DESKeySpec dks = new DESKeySpec(key);

            // 创建SecretKeyFactory,把DESKeySpec转换成SecretKey对象
            SecretKeyFactory keyFactory = SecretKeyFactory.getInstance(DES);
            SecretKey securekey = keyFactory.generateSecret(dks);

            // Cipher对象实际完成解密操作
            Cipher cipher = Cipher.getInstance(DES);

            // 用securekey初始化Cipher对象
            cipher.init(Cipher.DECRYPT_MODE, securekey, sr);
            return new String(cipher.doFinal(data), ENCODE);           
        }
}

 

 

上一篇: 用Servlet和JS操作Cookie

下一篇: