对称加密算法,AES 128位加密算法
/**
* 加密文件infilename,输出加密后的文件outfilename 返回AES加密密钥
*/
public static byte[] AesEnCrypt(String infilename, String outfilename)
throws Exception {
KeyGenerator keyGen = KeyGenerator.getInstance("AES");
keyGen.init(128);
SecretKey key = keyGen.generateKey();
Cipher cipher = Cipher.getInstance("AES");
InputStream in = new FileInputStream(infilename);
DataOutputStream out = new DataOutputStream(new FileOutputStream(
outfilename));
cipher.init(Cipher.ENCRYPT_MODE, key);
crypt(in, out, cipher);
in.close();
out.close();
return key.getEncoded();
}
/**
* 用密钥k解密文件infilename,输出明文文件outfilename
*
* @param infilename
* @param outfilename
* @param k
*/
public static void AesDeCrypt(String infilename, String outfilename,
byte[] k) {
try {
Cipher cipher = Cipher.getInstance("AES");
SecretKey key = new javax.crypto.spec.SecretKeySpec(k, "AES");
OutputStream out = new FileOutputStream(outfilename);
DataInputStream in = new DataInputStream(new FileInputStream(
infilename));
cipher.init(Cipher.DECRYPT_MODE, key);
crypt(in, out, cipher);
in.close();
out.close();
} catch (GeneralSecurityException exception) {
exception.printStackTrace();
} catch (IOException exception) {
exception.printStackTrace();
}
}
/**
* 自己定义的加 密函数
*
* @param in
* @param out
* @param cipher
* @throws IOException
* @throws GeneralSecurityException
*/
public static void crypt(InputStream in, OutputStream out, Cipher cipher)
throws IOException, GeneralSecurityException {
int blockSize = cipher.getBlockSize();
int outputSize = cipher.getOutputSize(blockSize);
byte[] inBytes = new byte[blockSize];
byte[] outBytes = new byte[outputSize];
int inLength = 0;
boolean more = true;
while (more) {
inLength = in.read(inBytes);
if (inLength == blockSize) {
int outLength = cipher.update(inBytes, 0, blockSize, outBytes);
out.write(outBytes, 0, outLength);
} else {
more = false;
}
}
if (inLength > 0)
outBytes = cipher.doFinal(inBytes, 0, inLength);
else
outBytes = cipher.doFinal();
out.write(outBytes);
}
public static String crypt(String in,Cipher cipher)
throws IOException, GeneralSecurityException {
StringBuffer out = new StringBuffer();
int blockSize = cipher.getBlockSize();
int outputSize = cipher.getOutputSize(blockSize);
byte[] inBytes = new byte[blockSize];
byte[] outBytes = new byte[outputSize];
int inLength = 0;
boolean more = true;
while (more) {
for(int i = 0;i<in.getBytes().length;i++)
{
System.out.println(in.getBytes().length*8);
if(in.getBytes().length>=i*blockSize)
{
System.arraycopy(in, 0*blockSize, inBytes, 0, blockSize);
cipher.update(inBytes, 0, blockSize, outBytes);
out.append(outBytes);
}
else
{
inLength = in.getBytes().length - i*blockSize;
more = false;
}
}
}
if (inLength > 0)
outBytes = cipher.doFinal(inBytes, 0, inLength);
else
outBytes = cipher.doFinal();
out.append(outBytes);
return out.toString();
}
分享到:
- 2009-02-21 15:14
- 浏览 1050
- 评论(1)
- 论坛回复 / 浏览 (1 / 5555)
- 查看更多
相关推荐
"java实现文件加密解密" Java 实现文件的加密与解密是指利用 Java 语言将资源文件(包括图片、动画等类型)进行简单的加密和解密。这种策略的原因和好处是将准备好的资源存储在云上,使用时通过网络进行读取即可,...
本项目"文件加密解密(完整项目)"专注于利用C#进行文件的安全处理,确保数据在传输和存储时的隐私性。 一、C#加密技术基础 C#中实现文件加密主要依赖于.NET Framework提供的加密类库,如System.Security....
《深入理解ENC文件加密解密工具:以PrimaSoft Encryption Utility为例》 在信息安全日益重要的今天,文件加密解密工具成为保护数据隐私的关键工具。"ENC文件加密解密工具",特别是PrimaSoft Encryption Utility,是...
文件加密解密系统是一种用于保护数据安全的重要工具,它能够对个人或组织的敏感信息进行加密,确保在传输或存储时不受未经授权的访问。在这个信息化的时代,数据安全已经成为企业和个人都必须关注的问题,因此,了解...
【标题】"全能文件加密解密源码.zip"是一个包含Visual Studio工程的压缩包,它提供了C#语言编写的源代码,用于实现文件的加密和解密功能。这个项目对于那些想要深入理解加密和解密机制,或者需要在自己的应用程序中...
本文将深入探讨“文件加密解密软件”的基础知识、工作原理以及如何选择和使用这类软件。 首先,让我们理解文件加密的基本概念。文件加密是一种通过特定算法将文件中的数据转化为无法直接读取的形式,这一过程称为...
在C#编程环境中,文件加密和解密是保护数据安全的重要技术。...以上就是关于"C#文件加密解密"这一主题的主要知识点。通过理解和应用这些知识,开发者可以在C#环境中构建自己的文件加密和解密系统,从而保障数据的安全。
本文将深入探讨“一款小巧的任意文件加密解密软件”,该软件利用了3DES加密算法,确保了数据的高度安全。同时,我们还会涉及到MD5哈希函数,它是文件完整性验证的重要工具。 3DES(Triple Data Encryption Standard...
根据提供的文件信息,本文将对"C语言文件加密解密系统"进行详细解析,重点在于理解其功能、工作原理以及核心代码实现。 ### C语言文件加密解密系统 #### 概述 该系统是一个基于C语言编写的文件加密解密工具,能够...
在这个特定的案例中,"MFC实现文本文件加密解密"是一个使用MFC框架编写的程序,它允许用户对文本文件进行加密和解密操作,确保敏感数据在传输或存储时的安全性。 在VC2010环境下,开发者通常会利用MFC的类库,如...
标题中的“移动定制版华为HG8546M配置文件加密解密工具”是指专为华为 HG8546M 路由器设计的一款软件工具,主要用于处理该型号路由器的配置文件。这款工具能够对配置文件进行加密和解密操作,确保数据的安全性和隐私...
文件加密解密代码
"文件加密解密工具源代码"提供了一种解决方案,它利用多种加密算法来保护数据,确保信息不被未经授权的用户访问。接下来,我们将深入探讨文件加密与解密的相关知识点。 **一、加密的基本概念** 加密是一种信息安全...
在VB(Visual Basic)编程环境中,我们可以创建一个简单的文件加密解密程序,这在保护敏感数据和隐私方面具有重要意义。本示例将介绍如何利用基本的加密算法来实现这一功能。VB提供了丰富的功能,让我们能够方便地...
总的来说,"小锁匠"是一款实用的文件加密解密工具,适用于需要批量处理文件安全的场景。其基于.NET Framework开发,可能采用了对称加密算法,并提供了源码供用户研究和定制。在使用时,用户应确保计算机已安装了合适...
利用汇编语言编写的文件加密解密程序,有详细解释说明、源代码
"实用小程序 全文件加密解密文件加密解密"这个标题暗示了我们关注的是一个用于保护文件安全的小程序,它提供了文件的加密和解密功能。这类工具通常用于确保敏感数据在传输或存储时不被未经授权的人员访问。 描述中...
米牛文件加密解密专家是一款专业强劲的文件加密解密软件,采用多线程加解密方式,加密速度快、安全性高、资源消耗低,不仅拥有文件/文件夹加密、解密、打开等功能,而且对本地加密/解密,更安全、更高效,并且软件...
Java 文件加密解密器 可对所有文件进行加密和解密,第一次运行加密,第二次运行解密。
首先,我们需要创建一个VB工程,工程名称可以自定义,例如“文本文件加密解密系统”。在该工程中,我们将设计一个窗体作为用户界面,窗体名称同样可以自定义,如“EncryptionDecryptionForm”。 #### 控件布局与...