JAVA 實(shí)現(xiàn)磁盤文件加解密操作的示例代碼
更新時(shí)間:2020年09月11日 09:28:53 作者:Nemo
這篇文章主要介紹了JAVA 實(shí)現(xiàn)磁盤文件加解密操作的示例代碼,幫助大家利用Java實(shí)現(xiàn)文件的加解密,感興趣的朋友可以了解下
簡(jiǎn)單實(shí)現(xiàn)了下:
import javax.crypto.BadPaddingException; import javax.crypto.Cipher; import javax.crypto.KeyGenerator; import javax.crypto.SecretKey; import java.io.*; import java.security.GeneralSecurityException; import java.security.SecureRandom; /** * 文件/目錄加解密相關(guān) * @author: Nemo * @date: 2019/3/19. */ public class FileCrote { /** * 加密后的文件后綴 */ private static final String SUBFIX = ".enc"; /** * 執(zhí)行路徑 */ private static String path = ""; /** * 執(zhí)行模式 1加密 2解密 */ private static String mode = "1"; /** * 執(zhí)行密碼 */ private static String pass = ""; private static String currentFilePath = null; /** * 根據(jù)路徑加密文件 * 1、如果是目錄,則找它下面的文件進(jìn)行加密 * 2、如果是文件,則直接加密 * @param path * @throws IOException */ private static void encrypt(String path) throws IOException, GeneralSecurityException { System.out.println("開始處理"+path); File file = new File(path); if(!file.exists()){ System.out.println("需加密的路徑不存在:"+path); return; } if(file.isDirectory()){ //目錄則遍歷其下的文件 File[] files = file.listFiles(); if(files == null){ return; } for (File subFile : files) { encrypt(subFile.getAbsolutePath()); } }else{ //文件則直接加密 encrypt(file); } } /** * 文件加密 * @param file * @throws IOException */ private static void encrypt(File file) throws IOException, GeneralSecurityException { String path = file.getAbsolutePath(); if(path.endsWith(SUBFIX)){ System.out.println("已加密文件不需再次加密"+path); return; } String encFilePath = path + SUBFIX; File encFile = new File(encFilePath); System.out.println("開始加密文件"+path); encryptFile(file,encFile,Cipher.ENCRYPT_MODE); } /** * 加解密文件操作 * @param srcFile * @param encFile * @throws IOException */ private static void encryptFile(File srcFile, File encFile,int mode) throws IOException, GeneralSecurityException { if(!srcFile.exists()){ System.out.println("source file not exixt"); return; } currentFilePath = srcFile.getAbsolutePath(); //密碼 Cipher cipher = getCipher(mode); FileInputStream fis = null; FileOutputStream fos = null; try { fis = new FileInputStream(srcFile); fos = new FileOutputStream(encFile); //真正處理 crypt(fis, fos, cipher); } catch (IOException e) { e.printStackTrace(); } finally { if (fis != null) { fis.close(); } if (fos != null) { fos.close(); } } //源文件刪除 srcFile.delete(); } /** * 得到加解密Cipher * @param mode * @return * @throws GeneralSecurityException */ private static Cipher getCipher(int mode) throws GeneralSecurityException { String type = "AES"; Cipher cipher = Cipher.getInstance(type+"/ECB/PKCS5Padding"); KeyGenerator kgen = KeyGenerator.getInstance(type); kgen.init(128, new SecureRandom(pass.getBytes())); SecretKey key = kgen.generateKey(); cipher.init(mode,key); return cipher; } /** * 加密解密流 * @param in 加密解密前的流 * @param out 加密解密后的流 * @param cipher 加密解密 * @throws IOException * @throws GeneralSecurityException */ private static void crypt(InputStream in, OutputStream out, Cipher cipher) throws IOException, GeneralSecurityException { int blockSize = cipher.getBlockSize() * 1000; 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); } /** * 根據(jù)路徑解密 * 1、如果是目錄,則找它下面的加密文件進(jìn)行解密 * 2、如果是文件,并且它是加密文件,則直接解密 * @param path * @throws IOException */ private static void decrypt(String path) throws IOException, GeneralSecurityException { System.out.println("開始處理"+path); File file = new File(path); if(!file.exists()){ System.out.println("需解密的路徑不存在:"+path); return; } if(file.isDirectory()){ //目錄則遍歷其下的文件 File[] files = file.listFiles(); if(files == null){ return; } for (File subFile : files) { decrypt(subFile.getAbsolutePath()); } }else{ decrypt(file); } } /** * 文件解密 * @param file * @throws IOException */ private static void decrypt(File file) throws IOException, GeneralSecurityException { String path = file.getAbsolutePath(); if(!path.endsWith(SUBFIX)){ System.out.println("非加密文件不需解密"+path); return; } System.out.println("開始解密文件"+path); String newPath = path.substring(0,path.length() - SUBFIX.length()); encryptFile(file,new File(newPath),Cipher.DECRYPT_MODE); } /** * 字符串是否非空 * @param s * @return */ private static boolean isNotEmpty(String s){ if (s == null || "".equals(s)) { return false; } return true; } /** * 開始處理 * @throws IOException * @throws GeneralSecurityException */ private static void deal() throws IOException, GeneralSecurityException { while (true) { print(); BufferedReader reader = new BufferedReader(new InputStreamReader(System.in)); String s = reader.readLine(); if("path".equals(s)) { System.out.println("\r\n請(qǐng)輸入執(zhí)行路徑\r\n"); while (true) { reader = new BufferedReader(new InputStreamReader(System.in)); s = reader.readLine(); if (!isNotEmpty(s)) { System.out.println("\r\n請(qǐng)輸入執(zhí)行路徑\r\n"); continue; }else { File file = new File(s); if(!file.exists()){ System.out.println("\r\n該路徑不存在,請(qǐng)重新輸入\r\n"); continue; } } path = s; break; } } else if("pass".equals(s)) { System.out.println("\r\n請(qǐng)輸入加/解密密碼\r\n"); while (true) { reader = new BufferedReader(new InputStreamReader(System.in)); s = reader.readLine(); if (!isNotEmpty(s)) { System.out.println("\r\n請(qǐng)輸入加/解密密碼\r\n"); continue; } pass = s; break; } } else if ("1".equals(s)) { mode = s; System.out.println("\r\n當(dāng)前已選模式:加密\n"); } else if ("2".equals(s)) { mode = s; System.out.println("\r\n當(dāng)前已選模式:解密\r\n"); }else if("start".equals(s)){ if(!isNotEmpty(path)) { System.out.println("\r\n請(qǐng)輸入加/解密密碼再開始\r\n"); continue; } if(!isNotEmpty(pass)) { System.out.println("\r\n請(qǐng)輸入執(zhí)行路徑后再開始\r\n"); continue; } if ("1".equals(mode)) { encrypt(path); System.out.println("\r\n\r\n操作完成\r\n\r\n"); } else { try { decrypt(path); System.out.println("\r\n\r\n操作完成\r\n\r\n"); }catch (BadPaddingException e) { System.out.println("文件:"+currentFilePath+"解密失敗,密碼錯(cuò)誤"); } } }else if("quit".equals(s)){ System.exit(-1); } else { System.out.println("\r\n輸入錯(cuò)誤\r\n"); } } } /** * 輸出提示語(yǔ) */ private static void print(){ System.out.println("\r\n" + "輸入path開始選擇執(zhí)行路徑\r\n" + "輸入pass開始選擇加/解密密碼\r\n" + "輸入如下數(shù)字以選擇處理模式:1 加密 2 解密\r\n" + "輸入start則開始執(zhí)行已選操作\r\n" + "輸入quit則退出程序\r\n" + "當(dāng)前選擇路徑:"+path+"\r\n" + "當(dāng)前選擇模式:"+mode+"\r\n" + "當(dāng)前選擇密碼:"+pass+"\r\n"); } public static void main(String args[]) throws IOException, GeneralSecurityException { deal(); } }
以上就是JAVA 實(shí)現(xiàn)磁盤文件加解密操作的示例代碼的詳細(xì)內(nèi)容,更多關(guān)于Java 文件加解密的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!
您可能感興趣的文章:
- Java實(shí)現(xiàn)AES/CBC/PKCS7Padding加解密的方法
- 詳細(xì)分析JAVA加解密算法
- Java實(shí)現(xiàn)與JS相同的Des加解密算法完整實(shí)例
- java加解密RSA使用方法代碼示例
- Java OpenSSL生成的RSA公私鑰進(jìn)行數(shù)據(jù)加解密詳細(xì)介紹
- Java加解密技術(shù)系列之RSA詳解
- Java實(shí)現(xiàn)DES加解密算法解析
- java使用RSA與AES加密解密的實(shí)例代碼詳解
- java使用Base64實(shí)現(xiàn)文件加密解密
- java實(shí)現(xiàn)置換密碼加密解密
- java實(shí)現(xiàn)仿射密碼加密解密
相關(guān)文章
JAVA像SQL一樣對(duì)List對(duì)象集合進(jìn)行排序
這篇文章主要介紹了JAVA像SQL一樣對(duì)List對(duì)象集合進(jìn)行排序的實(shí)現(xiàn)方法,文中講解非常細(xì)致,代碼幫助大家更好的理解和學(xué)習(xí),感興趣的朋友可以了解下2020-07-07Java通過(guò)在主循環(huán)中判斷Boolean來(lái)停止線程的方法示例
這篇文章主要介紹了Java通過(guò)在主循環(huán)中判斷Boolean來(lái)停止線程的方法,結(jié)合具體實(shí)例形式分析了java針對(duì)線程的判斷與停止操作相關(guān)實(shí)現(xiàn)技巧,需要的朋友可以參考下2017-04-04詳解Java設(shè)計(jì)模式編程中的訪問(wèn)者模式
這篇文章主要介紹了Java設(shè)計(jì)模式編程中的訪問(wèn)者模式,訪問(wèn)者模式的合理利用可以避免項(xiàng)目中出現(xiàn)大量重復(fù)的代碼,需要的朋友可以參考下2016-02-02SpringBoot favicon Chrome設(shè)置問(wèn)題解決方案
在本篇文章里小編給大家分享的是關(guān)于SpringBoot favicon Chrome設(shè)置問(wèn)題實(shí)例內(nèi)容,小的朋友們可以參考學(xué)習(xí)下。2020-02-02

一文講解Java的String、StringBuffer和StringBuilder的使用與區(qū)別
String是不可變的字符序列,而StringBuffer和StringBuilder是可變的字符序列,本文就來(lái)詳細(xì)的介紹一下Java的String、StringBuffer和StringBuilder的使用與區(qū)別,感興趣的可以了解一下
2024-03-03