`
暗黑小冷
  • 浏览: 1340 次
  • 性别: Icon_minigender_1
  • 来自: 上海
最近访客 更多访客>>
社区版块
存档分类
最新评论

关于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);
	}
}

 

分享到:
评论

相关推荐

    DES原理及实现步骤,以及VC++关于DES加密解密的详细源程序

    DES算法是这样工作的:如Mode为加密,则用Key 去把数据Data进行加密, 生成Data的密码形式(64位)作为DES的输出结果;...这样,便保证了核心数据(如PIN...下面是DES原理及实现步骤,以及VC++关于DES加密解密的详细源程序

    C语言实现DES加密解密算法

    DES加密解密算法的C语言实现 DES(Data Encryption Standard)是一种对称密钥 BLOCK 加密算法,使用 56 位密钥对 64 位数据块进行加密。下面是 DES 加密解密算法的 C 语言实现的知识点总结。 字节与二进制转换 在...

    3DES加密解密工具

    标题中的“3DES加密解密工具”指的是一个用于执行三重数据加密标准(3DES,Triple DES)的软件工具,这种工具通常用于保护敏感数据的安全,确保信息在传输过程中的机密性。3DES是DES(Data Encryption Standard,...

    des加密解密java实现版本

    在`cipher4j-master`这个项目中,可能包含了关于DES加密解密的Java实现,包括完整的类和示例代码,帮助开发者理解和使用DES。你可以下载并研究该项目,进一步了解如何在实际应用中集成DES加密解密功能。

    des加密解密_Des加密解密_DES加密_

    在给定的“des加密例程”中,可能包含了一个调用动态链接库(DLL)实现DES加密解密的示例代码。DLL是Windows操作系统中的一种共享库,可以被多个程序同时调用,节省内存资源并便于代码复用。这个示例可能涉及以下...

    DES/3DES加密解密工具

    对数据进行单DES或者3DES加密或者解密,如果密码长度为8字节则为DES加密或者解密

    DES.rar_Des加密解密_des_des加密解密算法_visual c

    在这个"DES.rar"压缩包中,包含了关于DES加密解密算法的学习资料,这可能包括源代码、教程或者示例项目,供用户了解和实践DES算法。"www.pudn.com.txt"可能是提供下载链接或者介绍的文本文件,而"DES"可能是一个包含...

    3DES加密解密工具类

    3DES加密解密的全工具类,快速帮助新人进行3Des加密解密

    java和javascript之间的DES加密解密

    Java和JavaScript之间的DES加密解密是信息安全领域中的一个重要话题,主要涉及到数据的保护和通信的安全。DES(Data Encryption Standard)是一种古老的对称加密算法,尽管它在安全性上已不被视为最佳选择,但在某些...

    用 MFC 实现 DES 加密解密算法

    在实现DES加密解密的过程中,首先需要理解DES的基本步骤,包括初始置换、扩展置换、8轮Feistel网络、逆扩展置换和逆初始置换。在MFC环境中,这些步骤可以通过定义类和函数来实现。例如,可以创建一个名为`CDES`的类...

    des加密解密工具 .exe文件

    des加密解密工具

    DES加密 解密 方法 MFC

    DES加密 解密 方法: DESr DESw 支持3DES加密 解密 类中利用函数重载的方式 实现两种加密方式 加密后为16进制字符串 使用方法: 实例化一个对象 然后就可以随便用了。 如 DES加密 解密 CString sd,sd2; yxyDES2 ...

    VB实现DES加密解密算法,vb加密和解密,VBA

    这需要创建一个.NET类库项目,实现DES加密解密功能,然后在VBA中通过CreateObject或早绑定的方式调用这些函数。 以下是VB.NET中实现DES加密解密的简单示例代码: ```vbnet Imports System.IO Imports System....

    DES加密解密(c++实现)

    DES加密解密(c++实现)

    DES加密解密VB6.0源代码

    在VB6.0(Visual Basic 6.0)环境中实现DES加密解密是编程中常见的一种需求,主要用于保护敏感数据的安全。下面将详细阐述DES加密解密原理及其在VB6.0中的实现方法。 1. **DES加密原理**: - **初始置换**:将明文...

    DES_zyj.rar_DES加密_DES加密算法_Des加密解密_des_加密解密

    在“DES_zyj.rar”压缩包中,“www.pudn.com.txt”可能是提供关于DES加密解密算法的进一步解释或示例代码的文本文件,而“DES_zyj”可能是一个包含实际实现或测试用例的程序文件。 在实际应用中,为了增强DES的安全...

    3DES加密解密

    标题中的“3DES加密解密”指的是在信息技术领域中,使用三重数据加密标准(3DES,Triple Data Encryption Standard)进行数据加密和解密的过程。3DES是一种加强版的DES加密算法,它通过三次应用DES的加密过程来提高...

    des加密解密工具

    在描述中提到的"DES加密解密工具"是一款专用于执行DES加密和解密操作的应用程序。这款工具的优点在于用户可以本地运行,避免了在线加解密可能带来的密钥泄露风险,确保了数据安全性。用户只需要输入相应的密钥和待...

    DES加密解密工具 DES加密解密工具

    DES加密解密工具DES加密解密工具DES加密解密工具DES加密解密工具DES加密解密工具DES加密解密工具DES加密解密工具DES加密解密工具DES加密解密工具

    DES_zyj.rar_DES 加密_DES加密_Des加密解密_des vc_vc 加密

    在"DES_zyj.rar"中,"www.pudn.com.txt"可能是提供了一些关于DES加密解密算法的介绍或者链接,而"DES_zyj"可能是源代码文件,包含了实现上述步骤的C++代码。通过阅读和分析这个源代码,你可以了解到如何在实际编程中...

Global site tag (gtag.js) - Google Analytics