赞
踩
以往都是直接对文件通过AES加密,是对内容的加密。此次是对文件设置编辑密码,同样是可逆的。
只是简单的基础逻辑,实现功能,还需要根据项目需要进行容错处理。加密解密过程相似,无非就是不加密码保存一下。
<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>
加密
/** * * @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);
}
当只引入itextpdf包时,就会报错:
java.lang.ClassNotFoundException: org.bouncycastle.asn1.ASN1OctetString
所以需要引入上文提到的第二个jar包bouncycastle
目前,加密后只能放到输出流中,还不能比较灵活的转换文件存放类型,我也只是在重新创建一个输入流再转为base64字符串。还有就是加密后临时保存的文件,如果删除,注意要在使用之后并关闭相关的占用才行,以免传输中出现问题。
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。