java如何对文件流加密

avatar
作者
筋斗云
阅读量:0

Java可以使用密码流对文件流进行加密。密码流是Java IO库提供的一种特殊的输入/输出流,它可以对底层的文件流进行加密和解密操作。下面是一个简单的示例代码,展示了如何使用密码流对文件进行加密。

import java.io.*; import javax.crypto.*; import javax.crypto.spec.SecretKeySpec;  public class FileEncryption {     public static void main(String[] args) {         String sourceFile = "source.txt";         String encryptedFile = "encrypted.txt";         String decryptedFile = "decrypted.txt";         String key = "1234567890abcdef"; // 密钥,16位字符          try {             encrypt(sourceFile, encryptedFile, key);             System.out.println("文件加密成功!");                          decrypt(encryptedFile, decryptedFile, key);             System.out.println("文件解密成功!");         } catch (Exception e) {             e.printStackTrace();         }     }      public static void encrypt(String sourceFile, String encryptedFile, String key) throws Exception {         File inputFile = new File(sourceFile);         File outputFile = new File(encryptedFile);          FileInputStream inputStream = new FileInputStream(inputFile);         FileOutputStream outputStream = new FileOutputStream(outputFile);          SecretKeySpec secretKeySpec = new SecretKeySpec(key.getBytes(), "AES");         Cipher cipher = Cipher.getInstance("AES");         cipher.init(Cipher.ENCRYPT_MODE, secretKeySpec);          CipherOutputStream cipherOutputStream = new CipherOutputStream(outputStream, cipher);          byte[] buffer = new byte[1024];         int bytesRead;         while ((bytesRead = inputStream.read(buffer)) != -1) {             cipherOutputStream.write(buffer, 0, bytesRead);         }          cipherOutputStream.close();         inputStream.close();     }      public static void decrypt(String encryptedFile, String decryptedFile, String key) throws Exception {         File inputFile = new File(encryptedFile);         File outputFile = new File(decryptedFile);          FileInputStream inputStream = new FileInputStream(inputFile);         FileOutputStream outputStream = new FileOutputStream(outputFile);          SecretKeySpec secretKeySpec = new SecretKeySpec(key.getBytes(), "AES");         Cipher cipher = Cipher.getInstance("AES");         cipher.init(Cipher.DECRYPT_MODE, secretKeySpec);          CipherInputStream cipherInputStream = new CipherInputStream(inputStream, cipher);          byte[] buffer = new byte[1024];         int bytesRead;         while ((bytesRead = cipherInputStream.read(buffer)) != -1) {             outputStream.write(buffer, 0, bytesRead);         }          outputStream.close();         cipherInputStream.close();     } } 

在上面的示例中,我们使用了AES算法对文件进行加密和解密。需要注意的是,AES算法需要一个16位的密钥,因此我们在代码中使用了一个16位的字符串作为密钥。实际应用中,你可能需要使用更安全的密钥生成方式。

这只是一个简单的示例,真实情况下你可能需要处理更多的异常情况,并采用更安全的加密方式。

广告一刻

为您即时展示最新活动产品广告消息,让您随时掌握产品活动新动态!