来一个简单的des算法程序例子
时间: 2024-09-11 07:05:41 浏览: 33
DES算法是一种对称密钥加密算法,用于加密和解密数据。在编程实现DES算法时,需要使用密钥进行加密和解密。以下是一个简化版的DES算法的Java示例代码:
```java
import javax.crypto.Cipher;
import javax.crypto.KeyGenerator;
import javax.crypto.SecretKey;
import javax.crypto.spec.SecretKeySpec;
import java.security.SecureRandom;
import java.util.Base64;
public class SimpleDESExample {
public static void main(String[] args) throws Exception {
String data = "Hello World!"; // 待加密的明文数据
String key = "12345678"; // DES算法的密钥长度应为8字节
// 加密
byte[] encryptedData = encryptDES(data.getBytes(), key);
String encodedEncryptedData = Base64.getEncoder().encodeToString(encryptedData);
System.out.println("加密后的数据: " + encodedEncryptedData);
// 解密
byte[] decryptedData = decryptDES(encryptedData, key);
String decodedData = new String(decryptedData);
System.out.println("解密后的数据: " + decodedData);
}
public static byte[] encryptDES(byte[] data, String key) throws Exception {
SecretKey secretKey = new SecretKeySpec(key.getBytes(), "DES");
Cipher cipher = Cipher.getInstance("DES/ECB/PKCS5Padding");
cipher.init(Cipher.ENCRYPT_MODE, secretKey);
return cipher.doFinal(data);
}
public static byte[] decryptDES(byte[] data, String key) throws Exception {
SecretKey secretKey = new SecretKeySpec(key.getBytes(), "DES");
Cipher cipher = Cipher.getInstance("DES/ECB/PKCS5Padding");
cipher.init(Cipher.DECRYPT_MODE, secretKey);
return cipher.doFinal(data);
}
}
```
请注意,上述代码仅为示例,实际应用中DES算法由于密钥长度较短(只有56位有效密钥长度),已经不再安全,不推荐在新的系统中使用。现代应用中应优先考虑使用更安全的加密算法,如AES等。
阅读全文