PDF文件加密解密-文件设置密码

简介: PDF文件加密解密

简介

以往都是直接对文件通过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字符串。还有就是加密后临时保存的文件,如果删除,注意要在使用之后并关闭相关的占用才行,以免传输中出现问题。

相关文章
|
1月前
|
Web App开发 Windows
【Windows】 chrome 如何下载网站在线预览PDF文件,保存到本地
【Windows】 chrome 如何下载网站在线预览PDF文件,保存到本地
155 0
|
1月前
|
JSON 关系型数据库 数据库
【python】Python将100个PDF文件对应的json文件存储到MySql数据库(源码)【独一无二】
【python】Python将100个PDF文件对应的json文件存储到MySql数据库(源码)【独一无二】
【python】Python将100个PDF文件对应的json文件存储到MySql数据库(源码)【独一无二】
|
3天前
|
算法 数据库 数据安全/隐私保护
rsa加密解密,使用rsa对密码加密
rsa加密解密,使用rsa对密码加密
|
14天前
|
弹性计算 运维 Shell
|
15天前
|
JSON 监控 JavaScript
【LLM】基于LLama构建智能助理实现与PDF文件智能对话
【4月更文挑战第12天】构建智能助理服务,实现与PDF的自由对话
|
17天前
|
存储 人工智能 安全
|
21天前
|
Python
python html(文件/url/html字符串)转pdf
python html(文件/url/html字符串)转pdf
10 0
|
25天前
|
Python
Python 合并多个 PDF 文件并建立书签目录
Python 合并多个 PDF 文件并建立书签目录
16 1
|
28天前
|
数据安全/隐私保护 C++
【C++】凯撒密码 实现加密与解密
【C++】凯撒密码 实现加密与解密
|
29天前
|
存储 安全 Java
Spring Security的密码加密和校验
本文介绍了Spring Security中密码的加密和校验。首先,在`SecurityConfig`配置类中添加了两个Bean,一个是`PasswordEncoder`的无操作实例,用于明文密码校验,另一个是`UserDetailsService`,用于创建内存中的用户信息。接着,文章对比了对称加密、非对称加密和摘要加密三种加密方式,并重点讲解了BCrypt摘要加密的特性,强调其安全性高于MD5。最后,通过代码示例展示了如何使用BCryptPasswordEncoder改造权限密码加密,确保密码的安全存储和校验。
42 6