RSA压缩加密/解压缩解密
AES压缩加密/解压缩解密,网上一般用base64来对byte[]编码,其实不需要,指定AES/CBC/PKCS5Padding来指定加密解密时候位数不对的情况下,用pkcs5padding来附加位数,不过这个时候读解密的文件的时候,要多读16位的验证位就不会报异常
加密: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】
- importjava.io.File;
- importjava.io.FileInputStream;
- importjava.io.FileOutputStream;
- importjava.io.ObjectInputStream;
- importjava.io.ObjectOutputStream;
- importjava.security.Key;
- importjava.security.KeyPair;
- importjava.security.KeyPairGenerator;
- importjava.security.PrivateKey;
- importjava.security.PublicKey;
- importjava.security.SecureRandom;
- importjava.util.Properties;
- importjava.util.UUID;
- importjava.util.zip.ZipEntry;
- importjava.util.zip.ZipInputStream;
- importjava.util.zip.ZipOutputStream;
-
- importjavax.crypto.Cipher;
-
- /**
- *对文件压缩加密/解密解压缩对象类
- *
- */
- publicclassZipEncrypt{
- privatestaticPrivateKeyprivateKey;
- privatestaticPublicKeypublicKey;
- privatestaticvoiddirectoryZip(ZipOutputStreamout,Filef,Stringbase)
- throwsException{
- //如果传入的是目录
- if(f.isDirectory()){
- File[]fl=f.listFiles();
- //创建压缩的子目录
- out.putNextEntry(newZipEntry(base+"/"));
- if(base.length()==0){
- base="";
- }else{
- base=base+"/";
- }
- for(inti=0;i<fl.length;i++){
- directoryZip(out,fl[i],base+fl[i].getName());
- }
- }else{
- //把压缩文件加入rar中
- out.putNextEntry(newZipEntry(base));
- FileInputStreamin=newFileInputStream(f);
- byte[]bb=newbyte[2048];
- intaa=0;
- while((aa=in.read(bb))!=-1){
- out.write(bb,0,aa);
- }
- in.close();
- }
- }
-
- /**
- *压缩文件
- *@paramzos
- *@paramfile
- *@throwsException
- */
- privatestaticvoidfileZip(ZipOutputStreamzos,Filefile)
- throwsException{
- if(file.isFile()){
- zos.putNextEntry(newZipEntry(file.getName()));
- FileInputStreamfis=newFileInputStream(file);
- byte[]bb=newbyte[2048];
- intaa=0;
- while((aa=fis.read(bb))!=-1){
- zos.write(bb,0,aa);
- }
- fis.close();
- System.out.println(file.getName());
- }else{
- directoryZip(zos,file,"");
- }
- }
-
- /**
- *解压缩文件
- *
- *@paramzis
- *@paramfile
- *@throwsException
- */
- privatestaticvoidfileUnZip(ZipInputStreamzis,Filefile)
- throwsException{
- ZipEntryzip=zis.getNextEntry();
- if(zip==null)
- return;
- Stringname=zip.getName();
- Filef=newFile(file.getAbsolutePath()+"/"+name);
- if(zip.isDirectory()){
- f.mkdirs();
- fileUnZip(zis,file);
- }else{
- f.createNewFile();
- FileOutputStreamfos=newFileOutputStream(f);
- byteb[]=newbyte[2048];
- intaa=0;
- while((aa=zis.read(b))!=-1){
- fos.write(b,0,aa);
- }
- fos.close();
- fileUnZip(zis,file);
- }
- }
-
- /**
- *对directory目录下的文件压缩,保存为指定的文件zipFile
- *
- *@paramdirectory
- *@paramzipFile
- */
- privatestaticvoidzip(Stringdirectory,StringzipFile){
- try{
- ZipOutputStreamzos=newZipOutputStream(newFileOutputStream(
- zipFile));
- fileZip(zos,newFile(directory));
- zos.close();
- }catch(Exceptione){
- e.printStackTrace();
- }
- }
-
- /**
- *解压缩文件zipFile保存在directory目录下
- *
- *@paramdirectory
- *@paramzipFile
- */
- privatestaticvoidunZip(Stringdirectory,StringzipFile){
- try{
- ZipInputStreamzis=newZipInputStream(
- newFileInputStream(zipFile));
- Filef=newFile(directory);
- f.mkdirs();
- fileUnZip(zis,f);
- zis.close();
- }catch(Exceptione){
- e.printStackTrace();
- }
- }
-
- /**
- *根据key的路径文件获得持久化成文件的key
- *<P>
- *例子:RsaEncrypt.getKey("c:/systemkey/private.key");
- *
- *@paramkeyPath
- *@return
- */
- publicstaticKeygetKey(StringkeyPath)throwsException{
- Keykey=null;
- FileInputStreamfis=newFileInputStream(keyPath);
- ObjectInputStreamofs=newObjectInputStream(fis);
- key=(Key)ofs.readObject();
- returnkey;
- }
-
- /**
- *把文件srcFile加密后存储为destFile
- *
- *@paramsrcFile
- *@paramdestFile
- */
- privatestaticvoidencrypt(StringsrcFile,StringdestFile,KeyprivateKey)
- throwsException{
- Ciphercipher=Cipher.getInstance("RSA");
- cipher.init(Cipher.ENCRYPT_MODE,privateKey);
- FileInputStreamfis=newFileInputStream(srcFile);
- FileOutputStreamfos=newFileOutputStream(destFile);
- byte[]b=newbyte[53];
- while(fis.read(b)!=-1){
- fos.write(cipher.doFinal(b));
- }
- fos.close();
- fis.close();
- }
-
- /**
- *把文件srcFile解密后存储为destFile
- *
- *@paramsrcFile
- *@paramdestFile
- *@paramprivateKey
- *@throwsException
- */
- privatestaticvoiddecrypt(StringsrcFile,StringdestFile,KeyprivateKey)
- throwsException{
- Ciphercipher=Cipher.getInstance("RSA");
- cipher.init(Cipher.DECRYPT_MODE,privateKey);
- FileInputStreamfis=newFileInputStream(srcFile);
- FileOutputStreamfos=newFileOutputStream(destFile);
- byte[]b=newbyte[64];
- while(fis.read(b)!=-1){
- fos.write(cipher.doFinal(b));
- }
- fos.close();
- fis.close();
- }
-
- /**
- *对目录srcFile下的所有文件目录进行先压缩后操作,然后保存为destfile
- *
- *@paramsrcFile
- *要操作的目录如c:/test/test
- *@paramdestfile
- *压缩加密后存放的文件名如c:/加密压缩文件.zip
- *@paramkeyfile
- *公钥存放地点
- */
- publicstaticvoidencryptZip(StringsrcFile,Stringdestfile,Stringkeyfile)throwsException{
- SecureRandomsr=newSecureRandom();
- KeyPairGeneratorkg=KeyPairGenerator.getInstance("RSA");
- kg.initialize(512,sr);
- //产生新密钥对
- KeyPairkp=kg.generateKeyPair();
- //获得私匙
- ZipEncrypt.privateKey=kp.getPrivate();
- //获得公钥
- ZipEncrypt.publicKey=kp.getPublic();
- Filef=newFile(keyfile);
- f.createNewFile();
- FileOutputStreamfos=newFileOutputStream(f);
- ObjectOutputStreamdos=newObjectOutputStream(fos);
- dos.writeObject(ZipEncrypt.publicKey);
- Filetemp=newFile(UUID.randomUUID().toString()+".zip");
- temp.deleteOnExit();
- //先压缩文件
- zip(srcFile,temp.getAbsolutePath());
- //对文件加密
- encrypt(temp.getAbsolutePath(),destfile,privateKey);
- temp.delete();
- }
-
- /**
- *对文件srcfile进行先解密后解压缩,然后解压缩到目录destfile下
- *
- *@paramsrcfile
- *要解密和解压缩的文件名如c:/目标.zip
- *@paramdestfile
- *解压缩后的目录如c:/abc
- *@parampublicKey
- *公钥
- */
- publicstaticvoiddecryptUnzip(Stringsrcfile,Stringdestfile,
- KeypublicKey)throwsException{
- //先对文件解密
- Filetemp=newFile(UUID.randomUUID().toString()+".zip");
- temp.deleteOnExit();
- decrypt(srcfile,temp.getAbsolutePath(),publicKey);
- //解压缩
- unZip(destfile,temp.getAbsolutePath());
- temp.delete();
- }
-
- publicstaticvoidmain(Stringargs[])throwsException{
- Filef=newFile(".");
- Propertiesprop=newProperties();;
- FileInputStreamfis=newFileInputStream("./conf.properties");
- prop.load(fis);
- //要压缩的目录
- StringsrcPath=prop.getProperty("SRC_PATH");
- //压缩后的存放文件
- StringdestZip=prop.getProperty("DEST_FILE");
- //压缩加密后的publickey
- Stringkeyfile=prop.getProperty("KEY_FILE");
- ZipEncrypt.encryptZip(srcPath,destZip,keyfile);
- /*解密
- ZipEncrypt.decryptUnzip("e:/comXXX/comxxxx.zip","d:/comxxx",ZipEncrypt
- .getKey("e:/comXXX/public.key"));
- */
- }
- }
- importjava.io.File;
- importjava.io.FileInputStream;
- importjava.io.FileOutputStream;
- importjava.io.ObjectInputStream;
- importjava.security.Key;
- importjava.security.SecureRandom;
- importjava.util.UUID;
- importjava.util.zip.ZipEntry;
- importjava.util.zip.ZipInputStream;
- importjava.util.zip.ZipOutputStream;
-
- importjavax.crypto.Cipher;
- importjavax.crypto.KeyGenerator;
- importjavax.crypto.SecretKey;
- importjavax.crypto.spec.IvParameterSpec;
- importjavax.crypto.spec.SecretKeySpec;
-
- /**
- *对文件加密/解密和压缩/解压缩对象类
- *@author赵成明
- */
- publicclassZipEncrypt{
- privatevoiddirectoryZip(ZipOutputStreamout,Filef,Stringbase)
- throwsException{
- //如果传入的是目录
- if(f.isDirectory()){
- File[]fl=f.listFiles();
- //创建压缩的子目录
- out.putNextEntry(newZipEntry(base+"/"));
- if(base.length()==0){
- base="";
- }else{
- base=base+"/";
- }
- for(inti=0;i<fl.length;i++){
- directoryZip(out,fl[i],base+fl[i].getName());
- }
- }else{
- //把压缩文件加入rar中
- out.putNextEntry(newZipEntry(base));
- FileInputStreamin=newFileInputStream(f);
- byte[]bb=newbyte[2048];
- intaa=0;
- while((aa=in.read(bb))!=-1){
- out.write(bb,0,aa);
- }
- in.close();
- }
- }
-
- /**
- *压缩文件
- *@paramzos
- *@paramfile
- *@throwsException
- */
- privatevoidfileZip(ZipOutputStreamzos,Filefile)
- throwsException{
- if(file.isFile()){
- zos.putNextEntry(newZipEntry(file.getName()));
- FileInputStreamfis=newFileInputStream(file);
- byte[]bb=newbyte[2048];
- intaa=0;
- while((aa=fis.read(bb))!=-1){
- zos.write(bb,0,aa);
- }
- fis.close();
- System.out.println(file.getName());
- }else{
- directoryZip(zos,file,"");
- }
- }
-
- /**
- *解压缩文件
- *
- *@paramzis
- *@paramfile
- *@throwsException
- */
- privatevoidfileUnZip(ZipInputStreamzis,Filefile)
- throwsException{
- ZipEntryzip=zis.getNextEntry();
- if(zip==null)
- return;
- Stringname=zip.getName();
- Filef=newFile(file.getAbsolutePath()+"/"+name);
- if(zip.isDirectory()){
- f.mkdirs();
- fileUnZip(zis,file);
- }else{
- f.createNewFile();
- FileOutputStreamfos=newFileOutputStream(f);
- byteb[]=newbyte[2048];
- intaa=0;
- while((aa=zis.read(b))!=-1){
- fos.write(b,0,aa);
- }
- fos.close();
- fileUnZip(zis,file);
- }
- }
-
- /**
- *对directory目录下的文件压缩,保存为指定的文件zipFile
- *
- *@paramdirectory
- *@paramzipFile
- */
- privatevoidzip(Stringdirectory,StringzipFile){
- try{
- ZipOutputStreamzos=newZipOutputStream(newFileOutputStream(
- zipFile));
- fileZip(zos,newFile(directory));
- zos.close();
- }catch(Exceptione){
- e.printStackTrace();
- }
- }
-
- /**
- *解压缩文件zipFile保存在directory目录下
- *
- *@paramdirectory
- *@paramzipFile
- */
- privatevoidunZip(Stringdirectory,StringzipFile){
- try{
- ZipInputStreamzis=newZipInputStream(newFileInputStream(zipFile));
- Filef=newFile(directory);
- f.mkdirs();
- fileUnZip(zis,f);
- zis.close();
- }catch(Exceptione){
- e.printStackTrace();
- }
- }
-
- /**
- *根据key的路径文件获得持久化成文件的key
- *<P>
- *例子:RsaEncrypt.getKey("c:/systemkey/private.key");
- *
- *@paramkeyPath
- *@return
- */
- privateKeygetKey(StringkeyPath)throwsException{
- FileInputStreamfis=newFileInputStream(keyPath);
- byte[]b=newbyte[16];
- fis.read(b);
- SecretKeySpecdks=newSecretKeySpec(b,"AES");
- fis.close();
- returndks;
- }
-
- /**
- *把文件srcFile加密后存储为destFile
- *
- *@paramsrcFile
- *@paramdestFile
- */
- privatevoidencrypt(StringsrcFile,StringdestFile,KeyprivateKey)
- throwsException{
- SecureRandomsr=newSecureRandom();
- Ciphercipher=Cipher.getInstance("AES/CBC/PKCS5Padding");
- IvParameterSpecspec=newIvParameterSpec(privateKey.getEncoded());
- cipher.init(Cipher.ENCRYPT_MODE,privateKey,spec,sr);
- FileInputStreamfis=newFileInputStream(srcFile);
- FileOutputStreamfos=newFileOutputStream(destFile);
- byte[]b=newbyte[2048];
- while(fis.read(b)!=-1){
- fos.write(cipher.doFinal(b));
- }
- fos.close();
- fis.close();
- }
-
- /**
- *把文件srcFile解密后存储为destFile
- *
- *@paramsrcFile
- *@paramdestFile
- *@paramprivateKey
- *@throwsException
- */
- privatevoiddecrypt(StringsrcFile,StringdestFile,KeyprivateKey)
- throwsException{
- SecureRandomsr=newSecureRandom();
- Cipherciphers=Cipher.getInstance("AES/CBC/PKCS5Padding");
- IvParameterSpecspec=newIvParameterSpec(privateKey.getEncoded());
- ciphers.init(Cipher.DECRYPT_MODE,privateKey,spec,sr);
- FileInputStreamfis=newFileInputStream(srcFile);
- FileOutputStreamfos=newFileOutputStream(destFile);
- byte[]b=newbyte[2064];
- while(fis.read(b)!=-1){
- fos.write(ciphers.doFinal(b));
- }
- fos.close();
- fis.close();
- }
-
- /**
- *对目录srcFile下的所有文件目录进行先压缩后操作,然后保存为destfile
- *
- *@paramsrcFile
- *要操作的目录如c:/test/test
- *@paramdestfile
- *压缩加密后存放的文件名如c:/加密压缩文件.zip
- *@paramkeyfile
- *公钥存放地点
- */
- publicvoidencryptZip(StringsrcFile,Stringdestfile,Stringkeyfile)throwsException{
- SecureRandomsr=newSecureRandom();
- KeyGeneratorkg=KeyGenerator.getInstance("AES");
- kg.init(128,sr);
- SecretKeykey=kg.generateKey();
- Filef=newFile(keyfile);
- if(!f.getParentFile().exists())
- f.getParentFile().mkdirs();
- f.createNewFile();
- FileOutputStreamfos=newFileOutputStream(f);
- fos.write(key.getEncoded());
- Filetemp=newFile(UUID.randomUUID().toString()+".zip");
- temp.deleteOnExit();
- //先压缩文件
- zip(srcFile,temp.getAbsolutePath());
- //对文件加密
- encrypt(temp.getAbsolutePath(),destfile,key);
- temp.delete();
- }
-
- /**
- *对文件srcfile进行先解密后解压缩,然后解压缩到目录destfile下
- *
- *@paramsrcfile
- *要解密和解压缩的文件名如c:/目标.zip
- *@paramdestfile
- *解压缩后的目录如c:/abc
- *@parampublicKey
- *公钥
- */
- publicvoiddecryptUnzip(Stringsrcfile,Stringdestfile,
- Stringkeyfile)throwsException{
- //先对文件解密
- Filetemp=newFile(UUID.randomUUID().toString()+".zip");
- temp.deleteOnExit();
- decrypt(srcfile,temp.getAbsolutePath(),this.getKey(keyfile));
- //解压缩
- unZip(destfile,temp.getAbsolutePath());
- temp.delete();
- }
-
- publicstaticvoidmain(Stringargs[])throwsException{
- longa=System.currentTimeMillis();
- newZipEncrypt().encryptZip("e:/com","e:/comXXX/page.zip","e:/comXXX/public.key");
- System.out.println(System.currentTimeMillis()-a);
- a=System.currentTimeMillis();
- newZipEncrypt().decryptUnzip("e:/comXXX/page.zip","e:/comxxx","e:/comXXX/public.key");
- System.out.println(System.currentTimeMillis()-a);
- }
- }
通过路径找到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】