`
cuker919
  • 浏览: 88367 次
  • 性别: Icon_minigender_1
  • 来自: 深圳
社区版块
存档分类
最新评论

Java对文件压缩/加密/解密/解压缩的例子,DES/RSA

 
阅读更多
RSA压缩加密/解压缩解密
  1. importjava.io.File;
  2. importjava.io.FileInputStream;
  3. importjava.io.FileOutputStream;
  4. importjava.io.ObjectInputStream;
  5. importjava.io.ObjectOutputStream;
  6. importjava.security.Key;
  7. importjava.security.KeyPair;
  8. importjava.security.KeyPairGenerator;
  9. importjava.security.PrivateKey;
  10. importjava.security.PublicKey;
  11. importjava.security.SecureRandom;
  12. importjava.util.Properties;
  13. importjava.util.UUID;
  14. importjava.util.zip.ZipEntry;
  15. importjava.util.zip.ZipInputStream;
  16. importjava.util.zip.ZipOutputStream;

  17. importjavax.crypto.Cipher;

  18. /**
  19. *对文件压缩加密/解密解压缩对象类
  20. *
  21. */
  22. publicclassZipEncrypt{
  23. privatestaticPrivateKeyprivateKey;
  24. privatestaticPublicKeypublicKey;
  25. privatestaticvoiddirectoryZip(ZipOutputStreamout,Filef,Stringbase)
  26. throwsException{
  27. //如果传入的是目录
  28. if(f.isDirectory()){
  29. File[]fl=f.listFiles();
  30. //创建压缩的子目录
  31. out.putNextEntry(newZipEntry(base+"/"));
  32. if(base.length()==0){
  33. base="";
  34. }else{
  35. base=base+"/";
  36. }
  37. for(inti=0;i<fl.length;i++){
  38. directoryZip(out,fl[i],base+fl[i].getName());
  39. }
  40. }else{
  41. //把压缩文件加入rar中
  42. out.putNextEntry(newZipEntry(base));
  43. FileInputStreamin=newFileInputStream(f);
  44. byte[]bb=newbyte[2048];
  45. intaa=0;
  46. while((aa=in.read(bb))!=-1){
  47. out.write(bb,0,aa);
  48. }
  49. in.close();
  50. }
  51. }

  52. /**
  53. *压缩文件
  54. *@paramzos
  55. *@paramfile
  56. *@throwsException
  57. */
  58. privatestaticvoidfileZip(ZipOutputStreamzos,Filefile)
  59. throwsException{
  60. if(file.isFile()){
  61. zos.putNextEntry(newZipEntry(file.getName()));
  62. FileInputStreamfis=newFileInputStream(file);
  63. byte[]bb=newbyte[2048];
  64. intaa=0;
  65. while((aa=fis.read(bb))!=-1){
  66. zos.write(bb,0,aa);
  67. }
  68. fis.close();
  69. System.out.println(file.getName());
  70. }else{
  71. directoryZip(zos,file,"");
  72. }
  73. }

  74. /**
  75. *解压缩文件
  76. *
  77. *@paramzis
  78. *@paramfile
  79. *@throwsException
  80. */
  81. privatestaticvoidfileUnZip(ZipInputStreamzis,Filefile)
  82. throwsException{
  83. ZipEntryzip=zis.getNextEntry();
  84. if(zip==null)
  85. return;
  86. Stringname=zip.getName();
  87. Filef=newFile(file.getAbsolutePath()+"/"+name);
  88. if(zip.isDirectory()){
  89. f.mkdirs();
  90. fileUnZip(zis,file);
  91. }else{
  92. f.createNewFile();
  93. FileOutputStreamfos=newFileOutputStream(f);
  94. byteb[]=newbyte[2048];
  95. intaa=0;
  96. while((aa=zis.read(b))!=-1){
  97. fos.write(b,0,aa);
  98. }
  99. fos.close();
  100. fileUnZip(zis,file);
  101. }
  102. }

  103. /**
  104. *对directory目录下的文件压缩,保存为指定的文件zipFile
  105. *
  106. *@paramdirectory
  107. *@paramzipFile
  108. */
  109. privatestaticvoidzip(Stringdirectory,StringzipFile){
  110. try{
  111. ZipOutputStreamzos=newZipOutputStream(newFileOutputStream(
  112. zipFile));
  113. fileZip(zos,newFile(directory));
  114. zos.close();
  115. }catch(Exceptione){
  116. e.printStackTrace();
  117. }
  118. }

  119. /**
  120. *解压缩文件zipFile保存在directory目录下
  121. *
  122. *@paramdirectory
  123. *@paramzipFile
  124. */
  125. privatestaticvoidunZip(Stringdirectory,StringzipFile){
  126. try{
  127. ZipInputStreamzis=newZipInputStream(
  128. newFileInputStream(zipFile));
  129. Filef=newFile(directory);
  130. f.mkdirs();
  131. fileUnZip(zis,f);
  132. zis.close();
  133. }catch(Exceptione){
  134. e.printStackTrace();
  135. }
  136. }

  137. /**
  138. *根据key的路径文件获得持久化成文件的key
  139. *<P>
  140. *例子:RsaEncrypt.getKey("c:/systemkey/private.key");
  141. *
  142. *@paramkeyPath
  143. *@return
  144. */
  145. publicstaticKeygetKey(StringkeyPath)throwsException{
  146. Keykey=null;
  147. FileInputStreamfis=newFileInputStream(keyPath);
  148. ObjectInputStreamofs=newObjectInputStream(fis);
  149. key=(Key)ofs.readObject();
  150. returnkey;
  151. }

  152. /**
  153. *把文件srcFile加密后存储为destFile
  154. *
  155. *@paramsrcFile
  156. *@paramdestFile
  157. */
  158. privatestaticvoidencrypt(StringsrcFile,StringdestFile,KeyprivateKey)
  159. throwsException{
  160. Ciphercipher=Cipher.getInstance("RSA");
  161. cipher.init(Cipher.ENCRYPT_MODE,privateKey);
  162. FileInputStreamfis=newFileInputStream(srcFile);
  163. FileOutputStreamfos=newFileOutputStream(destFile);
  164. byte[]b=newbyte[53];
  165. while(fis.read(b)!=-1){
  166. fos.write(cipher.doFinal(b));
  167. }
  168. fos.close();
  169. fis.close();
  170. }

  171. /**
  172. *把文件srcFile解密后存储为destFile
  173. *
  174. *@paramsrcFile
  175. *@paramdestFile
  176. *@paramprivateKey
  177. *@throwsException
  178. */
  179. privatestaticvoiddecrypt(StringsrcFile,StringdestFile,KeyprivateKey)
  180. throwsException{
  181. Ciphercipher=Cipher.getInstance("RSA");
  182. cipher.init(Cipher.DECRYPT_MODE,privateKey);
  183. FileInputStreamfis=newFileInputStream(srcFile);
  184. FileOutputStreamfos=newFileOutputStream(destFile);
  185. byte[]b=newbyte[64];
  186. while(fis.read(b)!=-1){
  187. fos.write(cipher.doFinal(b));
  188. }
  189. fos.close();
  190. fis.close();
  191. }

  192. /**
  193. *对目录srcFile下的所有文件目录进行先压缩后操作,然后保存为destfile
  194. *
  195. *@paramsrcFile
  196. *要操作的目录如c:/test/test
  197. *@paramdestfile
  198. *压缩加密后存放的文件名如c:/加密压缩文件.zip
  199. *@paramkeyfile
  200. *公钥存放地点
  201. */
  202. publicstaticvoidencryptZip(StringsrcFile,Stringdestfile,Stringkeyfile)throwsException{
  203. SecureRandomsr=newSecureRandom();
  204. KeyPairGeneratorkg=KeyPairGenerator.getInstance("RSA");
  205. kg.initialize(512,sr);
  206. //产生新密钥对
  207. KeyPairkp=kg.generateKeyPair();
  208. //获得私匙
  209. ZipEncrypt.privateKey=kp.getPrivate();
  210. //获得公钥
  211. ZipEncrypt.publicKey=kp.getPublic();
  212. Filef=newFile(keyfile);
  213. f.createNewFile();
  214. FileOutputStreamfos=newFileOutputStream(f);
  215. ObjectOutputStreamdos=newObjectOutputStream(fos);
  216. dos.writeObject(ZipEncrypt.publicKey);
  217. Filetemp=newFile(UUID.randomUUID().toString()+".zip");
  218. temp.deleteOnExit();
  219. //先压缩文件
  220. zip(srcFile,temp.getAbsolutePath());
  221. //对文件加密
  222. encrypt(temp.getAbsolutePath(),destfile,privateKey);
  223. temp.delete();
  224. }

  225. /**
  226. *对文件srcfile进行先解密后解压缩,然后解压缩到目录destfile下
  227. *
  228. *@paramsrcfile
  229. *要解密和解压缩的文件名如c:/目标.zip
  230. *@paramdestfile
  231. *解压缩后的目录如c:/abc
  232. *@parampublicKey
  233. *公钥
  234. */
  235. publicstaticvoiddecryptUnzip(Stringsrcfile,Stringdestfile,
  236. KeypublicKey)throwsException{
  237. //先对文件解密
  238. Filetemp=newFile(UUID.randomUUID().toString()+".zip");
  239. temp.deleteOnExit();
  240. decrypt(srcfile,temp.getAbsolutePath(),publicKey);
  241. //解压缩
  242. unZip(destfile,temp.getAbsolutePath());
  243. temp.delete();
  244. }

  245. publicstaticvoidmain(Stringargs[])throwsException{
  246. Filef=newFile(".");
  247. Propertiesprop=newProperties();;
  248. FileInputStreamfis=newFileInputStream("./conf.properties");
  249. prop.load(fis);
  250. //要压缩的目录
  251. StringsrcPath=prop.getProperty("SRC_PATH");
  252. //压缩后的存放文件
  253. StringdestZip=prop.getProperty("DEST_FILE");
  254. //压缩加密后的publickey
  255. Stringkeyfile=prop.getProperty("KEY_FILE");
  256. ZipEncrypt.encryptZip(srcPath,destZip,keyfile);
  257. /*解密
  258. ZipEncrypt.decryptUnzip("e:/comXXX/comxxxx.zip","d:/comxxx",ZipEncrypt
  259. .getKey("e:/comXXX/public.key"));
  260. */
  261. }
  262. }
AES压缩加密/解压缩解密,网上一般用base64来对byte[]编码,其实不需要,指定AES/CBC/PKCS5Padding来指定加密解密时候位数不对的情况下,用pkcs5padding来附加位数,不过这个时候读解密的文件的时候,要多读16位的验证位就不会报异常
  1. importjava.io.File;
  2. importjava.io.FileInputStream;
  3. importjava.io.FileOutputStream;
  4. importjava.io.ObjectInputStream;
  5. importjava.security.Key;
  6. importjava.security.SecureRandom;
  7. importjava.util.UUID;
  8. importjava.util.zip.ZipEntry;
  9. importjava.util.zip.ZipInputStream;
  10. importjava.util.zip.ZipOutputStream;

  11. importjavax.crypto.Cipher;
  12. importjavax.crypto.KeyGenerator;
  13. importjavax.crypto.SecretKey;
  14. importjavax.crypto.spec.IvParameterSpec;
  15. importjavax.crypto.spec.SecretKeySpec;

  16. /**
  17. *对文件加密/解密和压缩/解压缩对象类
  18. *@author赵成明
  19. */
  20. publicclassZipEncrypt{
  21. privatevoiddirectoryZip(ZipOutputStreamout,Filef,Stringbase)
  22. throwsException{
  23. //如果传入的是目录
  24. if(f.isDirectory()){
  25. File[]fl=f.listFiles();
  26. //创建压缩的子目录
  27. out.putNextEntry(newZipEntry(base+"/"));
  28. if(base.length()==0){
  29. base="";
  30. }else{
  31. base=base+"/";
  32. }
  33. for(inti=0;i<fl.length;i++){
  34. directoryZip(out,fl[i],base+fl[i].getName());
  35. }
  36. }else{
  37. //把压缩文件加入rar中
  38. out.putNextEntry(newZipEntry(base));
  39. FileInputStreamin=newFileInputStream(f);
  40. byte[]bb=newbyte[2048];
  41. intaa=0;
  42. while((aa=in.read(bb))!=-1){
  43. out.write(bb,0,aa);
  44. }
  45. in.close();
  46. }
  47. }

  48. /**
  49. *压缩文件
  50. *@paramzos
  51. *@paramfile
  52. *@throwsException
  53. */
  54. privatevoidfileZip(ZipOutputStreamzos,Filefile)
  55. throwsException{
  56. if(file.isFile()){
  57. zos.putNextEntry(newZipEntry(file.getName()));
  58. FileInputStreamfis=newFileInputStream(file);
  59. byte[]bb=newbyte[2048];
  60. intaa=0;
  61. while((aa=fis.read(bb))!=-1){
  62. zos.write(bb,0,aa);
  63. }
  64. fis.close();
  65. System.out.println(file.getName());
  66. }else{
  67. directoryZip(zos,file,"");
  68. }
  69. }

  70. /**
  71. *解压缩文件
  72. *
  73. *@paramzis
  74. *@paramfile
  75. *@throwsException
  76. */
  77. privatevoidfileUnZip(ZipInputStreamzis,Filefile)
  78. throwsException{
  79. ZipEntryzip=zis.getNextEntry();
  80. if(zip==null)
  81. return;
  82. Stringname=zip.getName();
  83. Filef=newFile(file.getAbsolutePath()+"/"+name);
  84. if(zip.isDirectory()){
  85. f.mkdirs();
  86. fileUnZip(zis,file);
  87. }else{
  88. f.createNewFile();
  89. FileOutputStreamfos=newFileOutputStream(f);
  90. byteb[]=newbyte[2048];
  91. intaa=0;
  92. while((aa=zis.read(b))!=-1){
  93. fos.write(b,0,aa);
  94. }
  95. fos.close();
  96. fileUnZip(zis,file);
  97. }
  98. }

  99. /**
  100. *对directory目录下的文件压缩,保存为指定的文件zipFile
  101. *
  102. *@paramdirectory
  103. *@paramzipFile
  104. */
  105. privatevoidzip(Stringdirectory,StringzipFile){
  106. try{
  107. ZipOutputStreamzos=newZipOutputStream(newFileOutputStream(
  108. zipFile));
  109. fileZip(zos,newFile(directory));
  110. zos.close();
  111. }catch(Exceptione){
  112. e.printStackTrace();
  113. }
  114. }

  115. /**
  116. *解压缩文件zipFile保存在directory目录下
  117. *
  118. *@paramdirectory
  119. *@paramzipFile
  120. */
  121. privatevoidunZip(Stringdirectory,StringzipFile){
  122. try{
  123. ZipInputStreamzis=newZipInputStream(newFileInputStream(zipFile));
  124. Filef=newFile(directory);
  125. f.mkdirs();
  126. fileUnZip(zis,f);
  127. zis.close();
  128. }catch(Exceptione){
  129. e.printStackTrace();
  130. }
  131. }

  132. /**
  133. *根据key的路径文件获得持久化成文件的key
  134. *<P>
  135. *例子:RsaEncrypt.getKey("c:/systemkey/private.key");
  136. *
  137. *@paramkeyPath
  138. *@return
  139. */
  140. privateKeygetKey(StringkeyPath)throwsException{
  141. FileInputStreamfis=newFileInputStream(keyPath);
  142. byte[]b=newbyte[16];
  143. fis.read(b);
  144. SecretKeySpecdks=newSecretKeySpec(b,"AES");
  145. fis.close();
  146. returndks;
  147. }

  148. /**
  149. *把文件srcFile加密后存储为destFile
  150. *
  151. *@paramsrcFile
  152. *@paramdestFile
  153. */
  154. privatevoidencrypt(StringsrcFile,StringdestFile,KeyprivateKey)
  155. throwsException{
  156. SecureRandomsr=newSecureRandom();
  157. Ciphercipher=Cipher.getInstance("AES/CBC/PKCS5Padding");
  158. IvParameterSpecspec=newIvParameterSpec(privateKey.getEncoded());
  159. cipher.init(Cipher.ENCRYPT_MODE,privateKey,spec,sr);
  160. FileInputStreamfis=newFileInputStream(srcFile);
  161. FileOutputStreamfos=newFileOutputStream(destFile);
  162. byte[]b=newbyte[2048];
  163. while(fis.read(b)!=-1){
  164. fos.write(cipher.doFinal(b));
  165. }
  166. fos.close();
  167. fis.close();
  168. }

  169. /**
  170. *把文件srcFile解密后存储为destFile
  171. *
  172. *@paramsrcFile
  173. *@paramdestFile
  174. *@paramprivateKey
  175. *@throwsException
  176. */
  177. privatevoiddecrypt(StringsrcFile,StringdestFile,KeyprivateKey)
  178. throwsException{
  179. SecureRandomsr=newSecureRandom();
  180. Cipherciphers=Cipher.getInstance("AES/CBC/PKCS5Padding");
  181. IvParameterSpecspec=newIvParameterSpec(privateKey.getEncoded());
  182. ciphers.init(Cipher.DECRYPT_MODE,privateKey,spec,sr);
  183. FileInputStreamfis=newFileInputStream(srcFile);
  184. FileOutputStreamfos=newFileOutputStream(destFile);
  185. byte[]b=newbyte[2064];
  186. while(fis.read(b)!=-1){
  187. fos.write(ciphers.doFinal(b));
  188. }
  189. fos.close();
  190. fis.close();
  191. }

  192. /**
  193. *对目录srcFile下的所有文件目录进行先压缩后操作,然后保存为destfile
  194. *
  195. *@paramsrcFile
  196. *要操作的目录如c:/test/test
  197. *@paramdestfile
  198. *压缩加密后存放的文件名如c:/加密压缩文件.zip
  199. *@paramkeyfile
  200. *公钥存放地点
  201. */
  202. publicvoidencryptZip(StringsrcFile,Stringdestfile,Stringkeyfile)throwsException{
  203. SecureRandomsr=newSecureRandom();
  204. KeyGeneratorkg=KeyGenerator.getInstance("AES");
  205. kg.init(128,sr);
  206. SecretKeykey=kg.generateKey();
  207. Filef=newFile(keyfile);
  208. if(!f.getParentFile().exists())
  209. f.getParentFile().mkdirs();
  210. f.createNewFile();
  211. FileOutputStreamfos=newFileOutputStream(f);
  212. fos.write(key.getEncoded());
  213. Filetemp=newFile(UUID.randomUUID().toString()+".zip");
  214. temp.deleteOnExit();
  215. //先压缩文件
  216. zip(srcFile,temp.getAbsolutePath());
  217. //对文件加密
  218. encrypt(temp.getAbsolutePath(),destfile,key);
  219. temp.delete();
  220. }

  221. /**
  222. *对文件srcfile进行先解密后解压缩,然后解压缩到目录destfile下
  223. *
  224. *@paramsrcfile
  225. *要解密和解压缩的文件名如c:/目标.zip
  226. *@paramdestfile
  227. *解压缩后的目录如c:/abc
  228. *@parampublicKey
  229. *公钥
  230. */
  231. publicvoiddecryptUnzip(Stringsrcfile,Stringdestfile,
  232. Stringkeyfile)throwsException{
  233. //先对文件解密
  234. Filetemp=newFile(UUID.randomUUID().toString()+".zip");
  235. temp.deleteOnExit();
  236. decrypt(srcfile,temp.getAbsolutePath(),this.getKey(keyfile));
  237. //解压缩
  238. unZip(destfile,temp.getAbsolutePath());
  239. temp.delete();
  240. }

  241. publicstaticvoidmain(Stringargs[])throwsException{
  242. longa=System.currentTimeMillis();
  243. newZipEncrypt().encryptZip("e:/com","e:/comXXX/page.zip","e:/comXXX/public.key");
  244. System.out.println(System.currentTimeMillis()-a);
  245. a=System.currentTimeMillis();
  246. newZipEncrypt().decryptUnzip("e:/comXXX/page.zip","e:/comxxx","e:/comXXX/public.key");
  247. System.out.println(System.currentTimeMillis()-a);
  248. }
  249. }
加密:encryptZip
通过路径找到Key:getKey
解密:decryptUnzip

转自【http://topic.csdn.net/u/20081215/09/6ad763bd-a158-488a-8e5e-b34cec2a0424.html及http://www.blogjava.net/zhaochengming/archive/2007/09/03/142396.html】
分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics