所谓加密,从应用角度就是使用指定的密钥将指定的数据进行加密。
我们不用关心具体算法的实现,只要关心应用本身需求和加密方法的使用即可。
如下是DES加密方法是用的示例,注意使用DES的话密钥长度应该是8的倍数。
package com.util; import java.security.SecureRandom; import javax.crypto.Cipher; import javax.crypto.SecretKey; import javax.crypto.SecretKeyFactory; import javax.crypto.spec.DESKeySpec; public class DESUtil { private static final String PASSWORD_CRYPT_KEY = "01234567";// 示例密钥 private final static String DES = "DES"; public static void main(String[] args) { System.out.println(encrypt("cuisuqiang", "12345678")); System.out.println(decrypt(encrypt("cuisuqiang", "12345678"),"12345678")); } /** * 加密 * @param src 数据 * @param key 密钥,长度必须是8的倍数 * @return 返回加密后的数据 */ private static byte[] encrypt(byte[] src, byte[] key) throws Exception { SecureRandom sr = new SecureRandom(); DESKeySpec dks = new DESKeySpec(key); SecretKeyFactory keyFactory = SecretKeyFactory.getInstance(DES); SecretKey securekey = keyFactory.generateSecret(dks); Cipher cipher = Cipher.getInstance(DES); cipher.init(Cipher.ENCRYPT_MODE, securekey, sr); return cipher.doFinal(src); } /** * 解密 * @param src 数据 * @param key 密钥,长度必须是8的倍数 * @return 返回解密后的原始数据 */ private static byte[] decrypt(byte[] src, byte[] key) throws Exception { SecureRandom sr = new SecureRandom(); DESKeySpec dks = new DESKeySpec(key); SecretKeyFactory keyFactory = SecretKeyFactory.getInstance(DES); SecretKey securekey = keyFactory.generateSecret(dks); Cipher cipher = Cipher.getInstance(DES); cipher.init(Cipher.DECRYPT_MODE, securekey, sr); return cipher.doFinal(src); } /** * 密码加密 */ public final static String encrypt(String data, String key) { try { return byte2hex(encrypt(data.getBytes(), key.getBytes())); } catch (Exception e) { e.printStackTrace(); } return null; } /** * 密码解密 */ public final static String decrypt(String data, String key) { try { return new String(decrypt(hex2byte(data), key.getBytes())); } catch (Exception e) { e.printStackTrace(); } return null; } // 字节码转换成16进制字符串 private static String byte2hex(byte bytes[]) { StringBuffer retString = new StringBuffer(); for (int i = 0; i < bytes.length; ++i) { retString.append(Integer.toHexString(0x0100 + (bytes[i] & 0x00FF)).substring(1).toUpperCase()); } return retString.toString(); } // 将16进制字符串转换成字节码 private static byte[] hex2byte(String hex) { byte[] bts = new byte[hex.length() / 2]; for (int i = 0; i < bts.length; i++) { bts[i] = (byte) Integer.parseInt(hex.substring(2 * i, 2 * i + 2),16); } return bts; } }
先加密,再将加密的内容反转。
请您到ITEYE看我的原创:http://cuisuqiang.iteye.com
或支持我的个人博客,地址:http://www.javacui.com
相关推荐
单次DES加密使用同一个密钥对数据进行一次加密;而双倍DES(也称为2DES或2-key TDEA)则是先用一个密钥加密,然后用另一个密钥再次加密,以提高安全性。不过,双倍DES并不完全等同于两倍的安全性,因为它存在中间...
在给定的“des加密例程”中,可能包含了一个调用动态链接库(DLL)实现DES加密解密的示例代码。DLL是Windows操作系统中的一种共享库,可以被多个程序同时调用,节省内存资源并便于代码复用。这个示例可能涉及以下...
标题中的“3DES加密解密工具”指的是一个用于执行三重数据加密标准(3DES,Triple DES)的软件工具,这种工具通常用于保护敏感数据的安全,确保信息在传输过程中的机密性。3DES是DES(Data Encryption Standard,...
在这个“Qt写的DES加密算法展示程序”中,我们将深入探讨DES(Data Encryption Standard)加密算法以及如何使用Qt来实现这一经典密码学技术。 **DES加密算法** DES是一种块加密算法,由IBM在1970年代初期开发,并...
6. **执行D3DES**:首先用第一个密钥执行DES加密,然后用第二个密钥执行DES解密,最后再用第一个密钥进行一次DES加密。这个过程就是D3DES的核心。 7. **密文后处理**:加密完成后,对密文进行逆初始置换,得到最终...
下面将详细介绍如何在SQL Server中使用C#实现DES加密和解密。 首先,理解DES的基本原理。DES是一种块加密算法,它对64位的数据块进行操作,但实际有效的密钥长度只有56位。它通过一系列的置换和混淆操作,将明文...
3DES(Triple Data Encryption Algorithm,三重数据加密算法)是一种强化版的DES(Data Encryption Standard)加密算法,它通过三次应用DES加密过程来提高安全性。在JavaScript中实现3DES加密通常是为了在网络通信中...
主要介绍了使用java自带des加密算法实现文件加密和字符串加密的示例,需要的朋友可以参考下
DES加密解密算法的C语言实现 DES(Data Encryption Standard)是一种对称密钥 BLOCK 加密算法,使用 56 位密钥对 64 位数据块进行加密。下面是 DES 加密解密算法的 C 语言实现的知识点总结。 字节与二进制转换 在...
在VB中,可以使用.NET框架提供的System.Security.Cryptography命名空间下的DESCryptoServiceProvider类来实现DES加密和解密。 1. **DES加密过程**: - 创建DESCryptoServiceProvider对象,这是VB中实现DES算法的...
在Delphi中实现DES加密通常需要调用低级的Pascal函数或使用第三方库如DCPCrypt等。 3. **源码实现**:描述中提到的"源码"是指用于在Delphi中实现DES加密和解密的具体代码。这些源码可能包括创建密钥、初始化加密和...
这将涉及到对TCP协议的理解,使用socket编程接口,以及在代码中集成DES加密算法的实现。 总结来说,基于DES加密的TCP聊天程序结合了传统的加密技术和网络通信的基本原理,通过学习和实践,不仅可以加深对网络安全和...
文件加密可以通过使用 Cipher 对象来实现,首先需要获取 DES 加密的密钥,然后使用 Cipher 对象来加密文件。 同样,在 Java 中,实现 RSA 加密算法也可以通过生成一对密钥,然后保存到 xml 文件中,以便以后获取私...
对数据进行单DES或者3DES加密或者解密,如果密码长度为8字节则为DES加密或者解密
DES加密算法的工作原理主要包括以下几个步骤: 1. **初始置换**:原始64位的数据块首先经过一个固定的初始置换,使得数据分布更均匀,增强安全性。 2. **16轮迭代**:每轮迭代都包括四个子步骤: - **子密钥产生*...
C_DesEncryptFile.cpp和C_DesEncryptFile.h文件很可能包含了一个用于实现文件加密的接口,它可能先生成一个随机的DES密钥,使用RSA加密这个密钥,然后用DES加密文件内容,最后将加密后的文件和RSA加密的密钥保存下来...
使用`crypto.createCipheriv`方法创建3DES加密器,需要指定加密算法('des-ede3'代表3DES),初始化向量(IV,通常为随机生成的8字节序列),以及密钥。例如: ```javascript const iv = Buffer.alloc(8, 0); // ...
在Java中,可以使用`javax.crypto`包来实现DES加密解密。首先,创建一个KeyGenerator对象,设置为DES算法,然后生成密钥。接着,创建Cipher对象,初始化为加密或解密模式,并使用密钥。最后,调用`doFinal()`方法...
- **System.Security.Cryptography命名空间**:C#中使用`DESCryptoServiceProvider`类来实现DES加密。首先需要创建一个`DESCryptoServiceProvider`实例,然后设置密钥和初始化向量(IV),最后使用`CreateEncryptor...
在Java中,我们可以使用`javax.crypto`包中的`Cipher`类来实现3DES加密和解密。首先,我们需要创建一个`SecretKeySpec`对象,用于存储我们的密钥。密钥长度可以是128位(16字节),但3DES实际只使用其中的112位或168...