import javax.crypto.KeyGenerator;
import javax.crypto.CipherInputStream;
import javax.crypto.Cipher;
import javax.crypto.CipherOutputStream;
import java.security.SecureRandom;
import java.security.Key;
import java.io.*;
import java.security.*;
/**
* Created by IntelliJ IDEA.
* User: 马千里
* Date: 2008-2-19
* Time: 8:52:29
* To change this template use File | Settings | File Templates.
*/
public class TestDES {
Key key;
public TestDES(String str) {
getKey(str);//生成密匙
}
/**
* 根据参数生成KEY
*/
public void getKey(String strKey) {
try {
KeyGenerator _generator = KeyGenerator.getInstance("DES");
_generator.init(new SecureRandom(strKey.getBytes()));
this.key = _generator.generateKey();
_generator = null;
} catch (Exception e) {
throw new RuntimeException("Error initializing SqlMap class. Cause: " + e);
}
}
/**
* 文件file进行加密并保存目标文件destFile中
*
* @param file 要加密的文件 如c:/test/srcFile.txt
* @param destFile 加密后存放的文件名 如c:/加密后文件.txt
*/
public void encrypt(String file, String destFile) throws Exception {
Cipher cipher = Cipher.getInstance("DES");
// cipher.init(Cipher.ENCRYPT_MODE, getKey());
cipher.init(Cipher.ENCRYPT_MODE, this.key);
InputStream is = new FileInputStream(file);
OutputStream out = new FileOutputStream(destFile);
CipherInputStream cis = new CipherInputStream(is, cipher);
byte[] buffer = new byte[1024];
int r;
while ((r = cis.read(buffer)) > 0) {
out.write(buffer, 0, r);
}
cis.close();
is.close();
out.close();
}
/**
* 文件采用DES算法解密文件
*
* @param file 已加密的文件 如c:/加密后文件.txt
* * @param destFile
* 解密后存放的文件名 如c:/ test/解密后文件.txt
*/
public void decrypt(String file, String dest) throws Exception {
Cipher cipher = Cipher.getInstance("DES");
cipher.init(Cipher.DECRYPT_MODE, this.key);
InputStream is = new FileInputStream(file);
OutputStream out = new FileOutputStream(dest);
CipherOutputStream cos = new CipherOutputStream(out, cipher);
byte[] buffer = new byte[1024];
int r;
while ((r = is.read(buffer)) >= 0) {
cos.write(buffer, 0, r);
}
cos.close();
out.close();
is.close();
}
public static void main(String[] args) throws Exception {
TestDES td = new TestDES("aaa");
td.encrypt("C:/Java实现文件的RSA和DES加密算法.doc", "c:/加密后文件1.doc"); //加密
td.decrypt("c:/加密后文件1.doc", "c:/解密后文件1.doc"); //解密
}
}
分享到:
相关推荐
Java中的DES(Data Encryption Standard)是一种对称加密算法,它基于一个固定的64位密钥对数据进行加密和解密。DES在80年代被广泛使用,但由于其密钥长度较短,现在已经被AES(Advanced Encryption Standard)所...
JAVA DES加密解密
在Java中实现DES加解密,我们需要使用`javax.crypto`包中的类。首先,我们需要创建一个密钥,这通常通过`KeyGenerator`类完成,指定DES作为算法。然后,我们使用`Cipher`类来执行加密和解密操作,该类提供了`init`...
java的DES加密解密:用于密码在数据库的加密,解码类
**JAVA实现DES加解密系统** DES(Data Encryption Standard)是一种经典的对称加密算法,它在信息安全领域有着广泛的应用。本文将深入探讨如何使用Java语言实现DES加解密系统,以及涉及的相关技术点。 首先,DES...
Java DES加解密算法 DES全称为Data Encryption Standard,即数据加密标准,是一种使用密钥加密的块
在Java中实现DES加密和解密是一项常见的任务,通常涉及到`javax.crypto`包中的类和接口。本篇文章将详细阐述DES加密解密的Java实现过程。 首先,我们需要了解DES算法的基本原理。DES是一种块密码,它将明文数据分成...
Java和JavaScript之间的DES加密解密是信息安全领域中的一个重要话题,主要涉及到数据的保护和通信的安全。DES(Data Encryption Standard)是一种古老的对称加密算法,尽管它在安全性上已不被视为最佳选择,但在某些...
DES算法实现包括文件选择,包括界面,可以实现文件的加密和解密
DES加密解密java工具类 public static final String KEY_ALGORITHM = "DES"; public static final String CIPHER_ALGORITHM = "DES/ECB/PKCS5PADDING"; validKeySpecException, NoSuchPaddingException, ...
本话题主要探讨如何在Linux环境下,使用C语言和Java实现DES加密和解密。 一、DES算法概述 DES是一种块密码,它将64位的数据块作为输入,通过一系列复杂的变换,将其转化为另一64位的密文。DES使用56位的密钥,但...
用java写的des算法加密及解密过程
2. JAVA DES加密解密: Java提供了javax.crypto包来处理加密解密。使用DES时,需要创建一个KeyGenerator对象,设置为DES算法,然后生成密钥。接着,使用Cipher类的`init()`方法初始化加密或解密模式,最后调用`...
des加密解密算法,通过DES加密解密实现一个String字符串的加密和解密.
本文将详细介绍如何在Java中实现DES加解密和MAC算法,并探讨其应用。 首先,DES是一种对称加密算法,由IBM公司开发,后被美国国家标准局采纳为标准。它使用64位的密钥对数据进行加密和解密,但实际有效密钥长度只有...
Java实现des加密解密算法,des加密解密算法
目前测试了通过的文件类 rar,txt,xml等
标题中的"Des.JAVA.rar_DES.java_DES加密_java DES 128bit_java des_加密解密"表明这是一个关于Java实现DES(Data Encryption Standard)加密算法的压缩包,其中包含用于加密和解密的源代码。DES是一种对称加密算法...
在Java中,DES加密解密主要通过`javax.crypto`包中的类来实现。首先,我们需要一个密钥,通常是8字节的字节数组。然后,使用`KeyGenerator`生成一个DES密钥。接下来,创建`Cipher`对象并初始化它,根据需要进行加密...
在Java和JavaScript中实现3DES加密和解密,主要涉及以下几个关键知识点: 1. **密钥生成**:3DES需要一个168位的密钥,但通常我们提供的是一个128位或更短的密钥。Java中的`javax.crypto.SecretKeyFactory`和`javax...