简介
以往都是直接对文件通过AES加密,是对内容的加密。此次是对文件设置编辑密码,同样是可逆的。
代码
只是简单的基础逻辑,实现功能,还需要根据项目需要进行容错处理。加密解密过程相似,无非就是不加密码保存一下。
1、两个jar包
<dependency>
<groupId>com.itextpdf</groupId>
<artifactId>itextpdf</artifactId>
<version>5.5.13.3</version>
</dependency>
<dependency>
<groupId>org.bouncycastle</groupId>
<artifactId>bcprov-jdk15on</artifactId>
<version>1.70</version>
</dependency>
2、加密解密
加密
/**
*
* @param src 未加密文件路径
* @param dest 加密后存放的路径
* @param password 密码
* @return
*/
public static void encrypt(String src, String dest,String password) {
try {
PdfReader reader = new PdfReader(src);// 待加密码的文件
PdfStamper stamper = new PdfStamper(reader, new FileOutputStream(dest));// 加完密码的文件
stamper.setEncryption(password.getBytes(),password.getBytes(), PdfWriter.ALLOW_PRINTING, false);// 设置密码文件打开密码文件编辑密码
stamper.close();//关闭流
reader.close();
} catch (Exception e) {
e.printStackTrace();
}
}
解密
/**
* 解密
* @param src 未加密文件路径
* @param dest 加密后存放的路径
* @param password 密码
*/
public static void decrypt(String src, String dest,String password) {
try {
PdfReader reader = new PdfReader(src,password.getBytes());
PdfStamper stamper = new PdfStamper(reader, new FileOutputStream(dest));// 加完密码的文件
stamper.close();//关闭流
reader.close();
} catch (Exception e) {
e.printStackTrace();
}
}
测试
public static void main(String[] args) {
String filePath = "D:\\Users\\admin\\Desktop\\计划表.pdf";
String savePath = "D:\\Users\\admin\\Desktop\\计划表 - 加密.pdf";
String savePath1 = "D:\\Users\\admin\\Desktop\\计划表 - 解密.pdf";
String password = "123456";
encrypt(filePath,savePath,password);
decrypt(savePath,savePath1,password);
}
3、报错
当只引入itextpdf包时,就会报错:
java.lang.ClassNotFoundException: org.bouncycastle.asn1.ASN1OctetString
所以需要引入上文提到的第二个jar包bouncycastle
总结
目前,加密后只能放到输出流中,还不能比较灵活的转换文件存放类型,我也只是在重新创建一个输入流再转为base64字符串。还有就是加密后临时保存的文件,如果删除,注意要在使用之后并关闭相关的占用才行,以免传输中出现问题。