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");
}
}
}
/**
* 輸出提示語
*/
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)文章
springboot 使用QQ郵箱發(fā)送郵件的操作方法
這篇文章主要介紹了springboot使用QQ郵箱發(fā)送郵件功能,本文通過實(shí)例圖文相結(jié)合給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2021-10-10
MyBatis學(xué)習(xí)教程(三)-MyBatis配置優(yōu)化
這篇文章主要介紹了MyBatis學(xué)習(xí)教程(三)-MyBatis配置優(yōu)化的相關(guān)資料,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下2016-05-05
SpringBoot實(shí)現(xiàn)公共字段自動(dòng)填充的方法步驟
這篇文章主要介紹了SpringBoot實(shí)現(xiàn)公共字段自動(dòng)填充的方法步驟,文中通過代碼示例講解的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作有一定的幫助,需要的朋友可以參考下2024-11-11
Java及數(shù)據(jù)庫對(duì)日期進(jìn)行格式化方式
這篇文章主要介紹了Java及數(shù)據(jù)庫對(duì)日期進(jìn)行格式化方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-03-03
Java中Collections.sort()排序方法舉例詳解
很多時(shí)候都需要對(duì)一些數(shù)據(jù)進(jìn)行排序的操作,這篇文章主要給大家介紹了關(guān)于Java中Collections.sort()方法舉例詳解的相關(guān)資料,使用Collections.sort()可以使用其sort()方法來對(duì)List、Set等集合進(jìn)行排序,需要的朋友可以參考下2024-02-02
Java CountDownLatch應(yīng)用場(chǎng)景代碼實(shí)例
這篇文章主要介紹了Java CountDownLatch應(yīng)用場(chǎng)景代碼實(shí)例,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-09-09
解決springcloud中Feign導(dǎo)入依賴為unknow的情況
這篇文章主要介紹了解決springcloud中Feign導(dǎo)入依賴為unknow的情況,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-03-03
Java中如何將String轉(zhuǎn)JSONObject
這篇文章主要介紹了Java中如何將String轉(zhuǎn)JSONObject,String類型轉(zhuǎn)JSONObject,下面有兩種方式可以進(jìn)行轉(zhuǎn)換,本文結(jié)合實(shí)例代碼給大家介紹的非常詳細(xì),需要的朋友可以參考下2023-05-05

