【开发技术】对文件内容进行加密-java
http://hi.baidu.com/java0804ms/item/111ea834fbd4d2f596f88d5a
实现效果:对文件内容进行加密,使之直接打开成为乱码,不以明文显示
实现步骤:1.key.txt里面存放的是加密文件的密码,这个是明文
2.源文件加密后,加密后的文件如果是压缩包必须通过程序解密后,方可打开,直接用软件是打不开加密后的压缩文件(此处需要注意一下,例如:将test.txt加密压缩后成为新的文件test.rar,test.rar必须通过程序解密后,才能用软件打开,如果直接打开test.rar是不行的)
3.已经测试,方案可行,详情请参见代码:
实现代码如下:
package com.test;
import java.io.File; import java.io.FileInputStream; import java.io.FileOutputStream; import java.security.Key; import java.security.SecureRandom; import java.util.UUID; import java.util.zip.ZipEntry; import java.util.zip.ZipInputStream; import java.util.zip.ZipOutputStream; import javax.crypto.Cipher; import javax.crypto.KeyGenerator; import javax.crypto.SecretKey; import javax.crypto.spec.IvParameterSpec; import javax.crypto.spec.SecretKeySpec;
/** * 对文件加密/解密和压缩/解压缩对象类 */ public class test { public static void main(String args[]) throws Exception{ //自定义压缩方式 String srcFile = "c://test.rar";//源文件 String destFile = "c://test1.rar";//加密后文件 Key privateKey = new test().getKey("c://key.txt");//存放解密密码 new test().encrypt(srcFile, destFile, privateKey);//加密压缩文件(压缩后的文件必须通过程序解密才能打开) new test().decrypt(destFile, "c://text2.rar", privateKey);//解密压缩文件 } private void directoryZip(ZipOutputStream out, File f, String base) throws Exception { // 如果传入的是目录 if (f.isDirectory()) { File[] fl = f.listFiles(); // 创建压缩的子目录 out.putNextEntry(new ZipEntry(base + "/")); if (base.length() == 0) { base = ""; } else { base = base + "/"; } for (int i = 0; i < fl.length; i++) { directoryZip(out, fl[i], base + fl[i].getName()); } } else { // 把压缩文件加入rar中 out.putNextEntry(new ZipEntry(base)); FileInputStream in = new FileInputStream(f); byte[] bb = new byte[2048]; int aa = 0; while ((aa = in.read(bb)) != -1) { out.write(bb, 0, aa); } in.close(); } }
/** * 压缩文件 * * @param zos * @param file * @throws Exception */ private void fileZip(ZipOutputStream zos, File file) throws Exception { if (file.isFile()) { zos.putNextEntry(new ZipEntry(file.getName())); FileInputStream fis = new FileInputStream(file); byte[] bb = new byte[2048]; int aa = 0; while ((aa = fis.read(bb)) != -1) { zos.write(bb, 0, aa); } fis.close(); System.out.println(file.getName()); } else { directoryZip(zos, file, ""); } }
/** * 解压缩文件 * * @param zis * @param file * @throws Exception */ private void fileUnZip(ZipInputStream zis, File file) throws Exception { ZipEntry zip = zis.getNextEntry(); if (zip == null) return; String name = zip.getName(); File f = new File(file.getAbsolutePath() + "/" + name); if (zip.isDirectory()) { f.mkdirs(); fileUnZip(zis, file); } else { f.createNewFile(); FileOutputStream fos = new FileOutputStream(f); byte b[] = new byte[2048]; int aa = 0; while ((aa = zis.read(b)) != -1) { fos.write(b, 0, aa); } fos.close(); fileUnZip(zis, file); } }
/** * 对directory目录下的文件压缩,保存为指定的文件zipFile * * @param directory * @param zipFile */ private void zip(String directory, String zipFile) { try { ZipOutputStream zos = new ZipOutputStream(new FileOutputStream( zipFile)); fileZip(zos, new File(directory)); zos.close(); } catch (Exception e) { e.printStackTrace(); } }
/** * 解压缩文件zipFile保存在directory目录下 * * @param directory * @param zipFile */ private void unZip(String directory, String zipFile) { try { ZipInputStream zis = new ZipInputStream( new FileInputStream(zipFile)); File f = new File(directory); f.mkdirs(); fileUnZip(zis, f); zis.close(); } catch (Exception e) { e.printStackTrace(); } }
/** * 根据key的路径文件获得持久化成文件的key * <P> * 例子: RsaEncrypt.getKey("c:/systemkey/private.key"); * * @param keyPath * @return */ private Key getKey(String keyPath) throws Exception { FileInputStream fis = new FileInputStream(keyPath); byte[] b = new byte[16]; fis.read(b); SecretKeySpec dks = new SecretKeySpec(b, "AES"); fis.close(); return dks; }
/** * 把文件srcFile加密后存储为destFile * * @param srcFile * @param destFile */ private void encrypt(String srcFile, String destFile, Key privateKey) throws Exception { SecureRandom sr = new SecureRandom(); Cipher cipher = Cipher.getInstance("AES/CBC/PKCS5Padding"); IvParameterSpec spec = new IvParameterSpec(privateKey.getEncoded()); cipher.init(Cipher.ENCRYPT_MODE, privateKey, spec, sr); FileInputStream fis = new FileInputStream(srcFile); FileOutputStream fos = new FileOutputStream(destFile); byte[] b = new byte[2048]; while (fis.read(b) != -1) { fos.write(cipher.doFinal(b)); } fos.close(); fis.close(); }
/** * 把文件srcFile解密后存储为destFile * * @param srcFile * @param destFile * @param privateKey * @throws Exception */ private void decrypt(String srcFile, String destFile, Key privateKey) throws Exception { SecureRandom sr = new SecureRandom(); Cipher ciphers = Cipher.getInstance("AES/CBC/PKCS5Padding"); IvParameterSpec spec = new IvParameterSpec(privateKey.getEncoded()); ciphers.init(Cipher.DECRYPT_MODE, privateKey, spec, sr); FileInputStream fis = new FileInputStream(srcFile); FileOutputStream fos = new FileOutputStream(destFile); byte[] b = new byte[2064]; while (fis.read(b) != -1) { fos.write(ciphers.doFinal(b)); } fos.close(); fis.close(); }
/** * 对目录srcFile下的所有文件目录进行先压缩后操作,然后保存为destfile * * @param srcFile * 要操作的目录 如c:/test/test * @param destfile * 压缩加密后存放的文件名 如c:/加密压缩文件.zip * @param keyfile * 公钥存放地点 */ public void encryptZip(String srcFile, String destfile, String keyfile) throws Exception { SecureRandom sr = new SecureRandom(); KeyGenerator kg = KeyGenerator.getInstance("AES"); kg.init(128, sr); SecretKey key = kg.generateKey(); File f = new File(keyfile); if (!f.getParentFile().exists()) f.getParentFile().mkdirs(); f.createNewFile(); FileOutputStream fos = new FileOutputStream(f); fos.write(key.getEncoded()); File temp = new File(UUID.randomUUID().toString() + ".zip"); temp.deleteOnExit(); // 先压缩文件 zip(srcFile, temp.getAbsolutePath()); // 对文件加密 encrypt(temp.getAbsolutePath(), destfile, key); temp.delete(); }
/** * 对文件srcfile进行先解密后解压缩,然后解压缩到目录destfile下 * * @param srcfile * 要解密和解压缩的文件名 如c:/目标.zip * @param destfile * 解压缩后的目录 如c:/abc * @param publicKey * 公钥 */ public void decryptUnzip(String srcfile, String destfile, String keyfile) throws Exception { // 先对文件解密 File temp = new File(UUID.randomUUID().toString() + ".zip"); temp.deleteOnExit(); decrypt(srcfile, temp.getAbsolutePath(), this.getKey(keyfile)); // 解压缩 unZip(destfile, temp.getAbsolutePath()); temp.delete(); } }
【开发技术】对文件内容进行加密-java的更多相关文章
- java 实现文件内容的加密和解密
package com.umapp.test; import java.io.FileInputStream; import java.io.FileOutputStream; import java ...
- iphone开发技术要学习的内容
一.iOS基础 1 开发环境搭建以及IOS组件.框架的概要介绍. 2 mac操作系统与iOS操作系统 3 xcode IDE开发环境的初始 二.C语言基础 1数据类型.表达式与控制流程语句 2数组.函 ...
- Java不走弯路教程(3.用户验证与文件内容查询)
3.用户验证与文件内容查询 在上一章中,我们完成了对指定文件内容的输出操作. 我们现在有如下格式的文件product.db id,product_name,product_detail 1,noteb ...
- 博主有偿带徒 《编程语言设计和实现》《MUD游戏开发》《软件破解和加密》《游戏辅助外挂》《JAVA开发》
<考研专题>操作系统原理 理论解答:8K 实战 1.5W CPU设计 理论解答:1W 实战 2.5W <编程语言设计和实现>初窥门径<5K>:编译原理.编译设计小试 ...
- Java EE开发技术课程第五周(Applet程序组件与AJAX技术)
1.Applet程序组件 1.1.定义: Applet是采用Java编程语言编写的小应用程序,该程序可以包含在HTML(标准通用标记语言的一个应用)页中,与在页中包含图像的方式大致相同.含有Apple ...
- Java Web开发技术教程入门-JSP基本语法和九大内置对象
这两天气温逐渐升高,好想把自己泡在冰块里······ 恩嗯摁蒽恩嗯摁蒽恩嗯摁蒽恩嗯摁蒽.......今天阅读到了这本书的第四章-JSP基本语法.经过第一天的阅读,我们明白JSP技术是Java Web开 ...
- Java Web开发技术教程入门-静态网页技术
昨天了解了构建动态网站的几种技术:Servlet技术.JSP技术,ASP技术和ASP.NET技术以及PHP技术.昨天的精髓在于JSP技术的运行原理:通过用户请求JSP文件,首先检查JSP文件的 ...
- 五种方式让你在java中读取properties文件内容不再是难题
一.背景 最近,在项目开发的过程中,遇到需要在properties文件中定义一些自定义的变量,以供java程序动态的读取,修改变量,不再需要修改代码的问题.就借此机会把Spring+SpringMVC ...
- java swing文件内容检索工具
Java相关技术 - 文件内容检索工具 拿到一个几百M甚至上G的project让你去学习 有时候你会想知道某个关键词是在哪个文件里 比如:spring MVC配置的@RequestMapping,你从 ...
随机推荐
- APP开发选择什么框架好? 请看这里!
背景 App的开发一般都需要满足Android和iOS两个系统环境,也就意味着一个App需要定制两套实现方案,造成开发成本和维护成本都很高.为了解决这个问题,最好的办法就是实现一套代码跨端运行,所以H ...
- fiddler基本介绍
1.Fiddler如何捕获HTTPS会话 点击Tools->Teleik Fiddler Option,勾选如下选项 点击"Yes" 后,就设置好了 2.fiddler的基本 ...
- 【bird-front】全自动数据表格组件bird-grid
bird-grid是bird-front前端框架中实现的全自动数据表格组件.组件内部处理数据加载.分页.排序.查询.新增.编辑等一系列操作.让业务表格的开发从繁复的增删查改中脱离出来,编码简洁却又功能 ...
- TurnipBit—MicroPython开发板:从积木式编程语言开始学做小小创客
编程.建模.制作动画和游戏--这些当初我们默认只有成年人玩得转的事情,现在早已经被无数小孩子给颠覆甚至玩出新境界了.热爱科技和动手的"创客"(Maker)现在在全世界都炙手可热.今 ...
- HTTP 错误 500.19 - Internal Server Error 0x80070005 0x80070003
IIS发布时错误 错误代码 0x80070005 一.权限:设置文件权限--属性-安全-添加everyone的读取权限(注意是给整个发布文件设置权限而不是config) 二.查看物理路径中是否存在中文 ...
- python3之运算符
1.python算术运算符 >>> a=15 >>> b=5 >>> a+b #加 20 >>> a-b #减 10 >& ...
- 8086cpu中的标志寄存器与比较指令
在8086CPU中有一个特殊的寄存器--标志寄存器,该寄存器不同于其他寄存器,普通寄存器是用来存放数据的读取整个寄存器具有一定的含义,但是标志寄存器是每一位都有固定的含义,记录在运算中产生的信息,标志 ...
- 高通msm8909耳机调试
http://blog.csdn.net/mike8825/article/details/69489865?locationnum=3&fps=1 1.DTS相应修改: DTS相关代码:ke ...
- FPGA学习之路——一路走来
既然选择了远方,便不顾风雨兼程,一路走下去. —韩彬 在看bingo的书时,看到这样写到.做什么事情都不容易,学习也是,所以一个词很重要不忘初心.作为一名大二的学生,我很高兴能够将自己学习FPGA的过 ...
- 类Unix平台程序调试
GNU Binutils GNU Binutils 建立main.c文件,内容如下: #include <stdio.h> void main() { int a = 5/0; } 编译m ...