zoukankan      html  css  js  c++  java
  • 关于DES加密

       今天因为公司需要用到DES加密,所以自己写了一个  ,和大家一起分享一下了哦!呵呵  好东西,大家一起分享! 

    下面是源码:

    package MyDES;
    
    import java.security.SecureRandom;
    
    import javax.crypto.Cipher;
    import javax.crypto.KeyGenerator;
    import javax.crypto.SecretKey;
    import javax.crypto.spec.SecretKeySpec;
    /**
     * DES 加密解密
     * @author spring key
     * @version  1.0
     * Emei vipa1888@163.com
     * 
     *
     */
    public class DES2 {
    
    	private final static String HEX = "0123456789abcdef";
    
    	private static void appendHex(StringBuffer sb, byte b) {
    		sb.append(HEX.charAt((b >> 4) & 0x0f)).append(HEX.charAt(b & 0x0f));
    	}
    	/**
    	 * 解密
    	 * @param raw  key
    	 * @param encrypted  加密后的字节
    	 * @return   返回解密后的字节
    	 * @throws Exception
    	 */
    	private static byte[] decrypt(byte[] raw, byte[] encrypted)
    			throws Exception {
    		SecretKeySpec skeySpec = new SecretKeySpec(raw, "AES");
    		Cipher cipher = Cipher.getInstance("AES");
    		cipher.init(Cipher.DECRYPT_MODE, skeySpec);
    		byte[] decrypted = cipher.doFinal(encrypted);
    		return decrypted;
    	}
    	/**
    	 * 解密
    	 * @param seed   key
    	 * @param encrypted   加密的字符
    	 * @return   返回解密的字符
    	 * @throws Exception
    	 */
    	public static String decrypt(String seed, String encrypted)
    			throws Exception {
    		byte[] rawKey = getRawKey(seed.getBytes());
    		byte[] enc = toByte(encrypted);
    		byte[] result = decrypt(rawKey, enc);
    		return new String(result);
    	}
    	/**
    	 * 加密
    	 * @param raw  key 
    	 * @param clear  
    	 * @return
    	 * @throws Exception
    	 */
    	private static byte[] encrypt(byte[] raw, byte[] clear) throws Exception {
    		SecretKeySpec skeySpec = new SecretKeySpec(raw, "AES");
    		Cipher cipher = Cipher.getInstance("AES");
    		cipher.init(Cipher.ENCRYPT_MODE, skeySpec);
    		byte[] encrypted = cipher.doFinal(clear);
    		return encrypted;
    	}
    	/**
    	 * 加密
    	 * @param seed  key
    	 * @param cleartext  需要加密的字符串
    	 * @return  返回加密的字符
    	 * @throws Exception
    	 */
    	public static String encrypt(String seed, String cleartext)
    			throws Exception {
    		byte[] rawKey = getRawKey(seed.getBytes());
    		byte[] result = encrypt(rawKey, cleartext.getBytes());
    		return toHex(result);
    	}
    	
    	public static String fromHex(String hex) {
    		return new String(toByte(hex));
    	}
    	/**
    	 * key 加密
    	 * @param seed
    	 * @return
    	 * @throws Exception
    	 */
    	private static byte[] getRawKey(byte[] seed) throws Exception {
    		KeyGenerator kgen = KeyGenerator.getInstance("AES");
    		SecureRandom sr = SecureRandom.getInstance("SHA1PRNG");
    		sr.setSeed(seed);
    		kgen.init(128, sr); // 192 and 256 bits may not be available
    		SecretKey skey = kgen.generateKey();
    		byte[] raw = skey.getEncoded();
    		return raw;
    	}
    
    	/**
    	 * to byte 
    	 * @param hexString
    	 * @return
    	 */
    	public static byte[] toByte(String hexString) {
    		int len = hexString.length() / 2;
    		byte[] result = new byte[len];
    		for (int i = 0; i < len; i++)
    			result[i] = Integer.valueOf(hexString.substring(2 * i, 2 * i + 2),
    					16).byteValue();
    		return result;
    	}
    	/**
    	 * 转为为16进制
    	 * @param buf  需要转化的byte
    	 * @return  返回转化后的字符串
    	 */
    	public static String toHex(byte[] buf) {
    		if (buf == null)
    			return "";
    		StringBuffer result = new StringBuffer(2 * buf.length);
    		for (int i = 0; i < buf.length; i++) {
    			appendHex(result, buf[i]);
    		}
    		return result.toString();
    	}
    	/**
    	 * 转为为16进制
    	 * @param buf  需要转化的byte
    	 * @return  返回转化后的字符串
    	 */
    	public static String toHex(String txt) {
    		return toHex(txt.getBytes());
    	}
    
    	public static void main(String[] args) throws Exception {
    		String seed = "abc";   //key
    		String cleartext = "spring key";   //加密字符
    		System.out.println("seed---" + seed + "\ncleartext---" + cleartext);
    		String s1 = DES2.encrypt(seed, cleartext);
    		System.out.println("加密后---"+s1);
    		String s2 = DES2.decrypt(seed, s1);
    		System.out.println("解密后---"+s2);
    	}
    }
    


     

  • 相关阅读:
    一步步学习SPD2010--第十三章节--管理SP Server环境的Web内容(2)--理解SP Server2010的Web内容管理
    一步步学习SPD2010--第十三章节--管理SP Server环境的Web内容(1)--创建一个发布网站
    一步步学习SPD2010--第十三章节--管理SP Server环境的Web内容
    一步步学习SPD2010--第十二章节--理解可用性和可接入性(8)--关键点
    亚马逊推自家云备份产品,第三方云备份厂商压力山大 中国存储网
    几何概率模型是什么
    宋浩《概率论与数理统计》笔记---1..1.1-1.1.3、概率论基本概念
    机器学习疑难---1、什么是多元线性回归
    最大似然估计线性回归实例
    Hopfield神经网络 简介
  • 原文地址:https://www.cnblogs.com/springskyhome/p/3689963.html
Copyright © 2011-2022 走看看