写在前面:本文主要为了实现能对pdf文件进行在线签名、盖章功能。采用的技术是pageoffice。说简单吧他坑点挺多的,说难吧 他代码量确实不多。本文总结了一下我自己遇到的问题以及解决方式。
注:实现pdf签名、签章的前提是pageoffice版本必须为 5.0以上

项目结构

SpringBoot集成knife4j文档为空 springboot集成pageoffice_服务器端

真的没几个文件

1、添加依赖
<!-- 添加Sqlite依赖(可选:如果不需要使用印章功能的话,不需要添加此依赖 )-->
        <dependency>
            <groupId>org.xerial</groupId>
            <artifactId>sqlite-jdbc</artifactId>
            <version>3.7.2</version>
        </dependency>
        <!-- 添加PageOffice依赖(必须) -->
        <dependency>
            <groupId>com.zhuozhengsoft</groupId>
            <artifactId>pageoffice</artifactId>
            <version>5.2.0.12</version>
        </dependency>
        <!--此处前端模板用的thymeleaf 可自行选择 -->
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-thymeleaf</artifactId>
        </dependency>
2、注册bean(直接复制即可)
package com.zks.pageoffice.controller;

import org.springframework.beans.factory.annotation.Value;
import org.springframework.boot.web.servlet.ServletRegistrationBean;
import org.springframework.context.annotation.Bean;
import org.springframework.stereotype.Component;
import org.springframework.web.bind.annotation.RestController;

/**
 * @Package: com.zks.pageoffice
 * @ClassName: DemoController
 * @Author: ZhouKaiShun
 * @CreateTime: 2021/9/10 10:18
 * @Description:
 */
@Component
public class RegistrationBean {

    @Value("${posyspath}")
    private String poSysPath;

    @Value("${popassword}")
    private String poPassWord;



    /**
     * 添加PageOffice的服务器端授权程序Servlet(必须)
     * @return
     */
    @Bean
    public ServletRegistrationBean servletRegistrationBean() {
        com.zhuozhengsoft.pageoffice.poserver.Server poserver = new com.zhuozhengsoft.pageoffice.poserver.Server();
        //设置PageOffice注册成功后,license.lic文件存放的目录
        poserver.setSysPath(poSysPath);
        ServletRegistrationBean srb = new ServletRegistrationBean(poserver);
        srb.addUrlMappings("/poserver.zz");
        srb.addUrlMappings("/posetup.exe");
        srb.addUrlMappings("/pageoffice.js");
        srb.addUrlMappings("/jquery.min.js");
        srb.addUrlMappings("/pobstyle.css");
        srb.addUrlMappings("/sealsetup.exe");
        return srb;
    }

    /**
     * 添加印章管理程序Servlet(可选)
     * @return
     */
    @Bean
    public ServletRegistrationBean servletRegistrationBean2() {
        com.zhuozhengsoft.pageoffice.poserver.AdminSeal adminSeal = new com.zhuozhengsoft.pageoffice.poserver.AdminSeal();
        //设置印章管理员admin的登录密码
        adminSeal.setAdminPassword(poPassWord);
        //设置印章数据库文件poseal.db存放的目录
        adminSeal.setSysPath(poSysPath);
        ServletRegistrationBean srb = new ServletRegistrationBean(adminSeal);
        srb.addUrlMappings("/adminseal.zz");
        srb.addUrlMappings("/sealimage.zz");
        srb.addUrlMappings("/loginseal.zz");
        return srb;
    }

}
3、controller调用
package com.zks.pageoffice.controller;

import com.zhuozhengsoft.pageoffice.FileSaver;
import com.zhuozhengsoft.pageoffice.OpenModeType;
import com.zhuozhengsoft.pageoffice.PDFCtrl;
import com.zhuozhengsoft.pageoffice.PageOfficeCtrl;
import lombok.extern.slf4j.Slf4j;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestMethod;
import org.springframework.web.bind.annotation.RestController;
import org.springframework.web.servlet.ModelAndView;

import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.util.Map;

/**
 * @Package: com.zks.pageoffice
 * @ClassName: PDFInsertSealController
 * @Author: ZhouKaiShun
 * @CreateTime: 2021/9/10 10:19
 * @Description:
 */
@RestController
@Slf4j
public class PDFInsertSealController {


    @Value("${spring.profiles.active}")
    public String active;

    @Value("${signpath}")
    public String signPath;

    @Value("${sealpath}")
    private String sealPath;


    @RequestMapping(value = "/", method = RequestMethod.GET)
    public ModelAndView showIndex() {
        ModelAndView mv = new ModelAndView("Index");
        return mv;
    }

    /**
     * @description:盖章功能
     * @return:
     * @author: ZhouKaiShun
     * @time: 2021/9/10 13:40
     */

    @GetMapping("/AddSeal")
    public ModelAndView showWord(HttpServletRequest request, Map<String, Object> map) {
        log.info("准备盖章");
        PDFCtrl pdfCtrl1 = new PDFCtrl(request);
        //此行必须
        pdfCtrl1.setServerPage(request.getContextPath() + "/poserver.zz");
        //设置保存页面
        pdfCtrl1.setSaveFilePage("AddSeal/save");
        // Create custom toolbar
        pdfCtrl1.addCustomToolButton("保存", "Save()", 1);
        pdfCtrl1.addCustomToolButton("加盖印章", "InsertSeal()", 2);

        //此处路径为服务器端文档路径  如果是Linux服务器上的路径,前面需要加“file://”  (这个点找了好久......)
        pdfCtrl1.webOpen(active.equals("prod") ? "file://" + sealPath : sealPath);
        map.put("pageoffice", pdfCtrl1.getHtmlCode("PDFCtrl1"));
        ModelAndView mv = new ModelAndView("AddSeal/PDF1");
        return mv;
    }

    /**
     * @description:签字功能
     * @return:
     * @author: ZhouKaiShun
     * @time: 2021/9/10 13:40
     */
    @GetMapping("AddSign")
    public ModelAndView showWord11(HttpServletRequest request, Map<String, Object> map) {
        log.info("准备签字");
        //PageOfficeCtrl pdfCtrl1 = new PageOfficeCtrl(request);
        PDFCtrl pdfCtrl1 = new PDFCtrl(request);
        //此行必须
        pdfCtrl1.setServerPage(request.getContextPath() + "/poserver.zz");
        //设置保存页面
        pdfCtrl1.setSaveFilePage("AddSign/save");
        // Create custom toolbar
        pdfCtrl1.addCustomToolButton("保存", "Save()", 1);
        pdfCtrl1.addCustomToolButton("签字", "AddHandSign()", 3);
        //此处路径为服务器端文档路径   如果是Linux服务器上的路径,前面需要加“file://”  (这个点找了好久......)
        pdfCtrl1.webOpen(active.equals("prod") ? "file://" + signPath : signPath);
        map.put("pageoffice", pdfCtrl1.getHtmlCode("PDFCtrl1"));
        ModelAndView mv = new ModelAndView("AddSign/PDF1");
        return mv;
    }


    @RequestMapping("/AddSeal/save")
    public void save(HttpServletRequest request, HttpServletResponse response) {
        FileSaver fs = new FileSaver(request, response);
        //此处路径为服务器端文档路径
        fs.saveToFile(sealPath);
        fs.close();
    }

    @RequestMapping("/AddSign/save")
    public void save2(HttpServletRequest request, HttpServletResponse response) {
        FileSaver fs = new FileSaver(request, response);
        //此处路径为服务器端文档路径
        fs.saveToFile(signPath);
        fs.close();
    }

}

两个主要接口,一个用于签名,一个用于盖章

controller中的一些配置项

application-dev.yml

server:
  port: 8080

# 用于存放注册的信息以及.db文件,这个db文件包含了签章的一些信息,pageoffice帮我们集成好了 我们不用管,只需要自己创建签章即可
posyspath: d:/lic/
# 默认密码,管理签章的默认账号  admin  111111
popassword: 111111
# 用于签名的文件地址
signpath: D:\doc\AddSign\test1.pdf
# 用于盖章的文件路径
sealpath: D:\doc\AddSeal\test1.pdf

spring:
  thymeleaf:
    prefix: classpath:/templates/
    suffix: .html
    cache: false

application-prod.yml

server:
  port: 8011

# 用于存放注册的信息以及.db文件,这个db文件包含了签章的一些信息,pageoffice帮我们集成好了 我们不用管,只需要自己创建签章即可
posyspath: /usr/javaproject/pageoffice/lic/
# 默认密码,管理签章的默认账号  admin  111111
popassword: 111111
# 用于签名的文件地址
signpath: /usr/javaproject/static/pageoffice/sign/test.pdf
# 用于盖章的文件路径
sealpath: /usr/javaproject/static/pageoffice/seal/test.pdf

spring:
  thymeleaf:
    prefix: classpath:/templates/
    suffix: .html
    cache: false

application.yml (此处测试默认dev)

spring:
  profiles:
    active: dev

上述路径需自行创建好,准备好用于测试的pdf文件放入指定路径。项目启动后会在我们的 d:lic下看到以下文件

SpringBoot集成knife4j文档为空 springboot集成pageoffice_java_02


这个lic文件是安装pageoffice客户端后的注册信息。(注意:此次的注册码要用 专业版 才可使用签字、签章的功能)

poseal.db暂时忽略 后面再提

到这里我们就可以启动项目了,可以看到如下界面

SpringBoot集成knife4j文档为空 springboot集成pageoffice_spring_03

点击的时候如果没有安装pageoffice客户端,则会提示安装,直接下载安装即可。这里下载后需要注册,组织什么的可以随便填,最后的序列号,需要到官网下载一个案例(注意版本),里面有序列号,注意要使用专业版试用序列号

安装完毕后点击 加盖签章会提示输入用户名密码

SpringBoot集成knife4j文档为空 springboot集成pageoffice_java_04

这里的用户密码是签章的关联关系,由管理员创建,并且这里不能登录admin 111111 会提示

SpringBoot集成knife4j文档为空 springboot集成pageoffice_pageoffice_05


所以我们需要自己创建,创建地址是:http://localhost:8080/loginseal.zz

SpringBoot集成knife4j文档为空 springboot集成pageoffice_spring_06


这里的账号密码是admin 111111,这里的数据就是之前我们提到的 poseal.db 文件

这个文件我们需要去官网下载一个demo包,然后从实例项目中的 Samples5\WEB-INF\lib 这个路径下拿到
官网下载demo地址:/下载时记得对应大版本号,案例里面有很多资料,如果出问题了可以查看参考

拿到poseal.db文件后,替换我们本地的文件,重启服务,然后访问印章管理,去新建印章

SpringBoot集成knife4j文档为空 springboot集成pageoffice_spring boot_07

**这时候我们就可去盖章了,输入刚刚的用户名以及默认密码,修改密码后确定
**

SpringBoot集成knife4j文档为空 springboot集成pageoffice_服务器端_08


SpringBoot集成knife4j文档为空 springboot集成pageoffice_spring_09


这里可以选择你刚刚新建的印章,点击确定,然后选择需要盖章到哪里后再点鼠标左键,然后保存,即可完成盖章

SpringBoot集成knife4j文档为空 springboot集成pageoffice_java_10

保存后,可在本地的文件夹下查看,章已经盖好了,签字同理。

SpringBoot集成knife4j文档为空 springboot集成pageoffice_java_11

SpringBoot集成knife4j文档为空 springboot集成pageoffice_spring boot_12


至此本地测试完毕,下面可以部署到服务器。部署到服务器需要注意的点我上面的代码里都有注释,直接根据我的配置改下路径放好文件即可。最坑的点莫过于 服务器上的资源路径前需要添加 “file://”,然后再加自己的路径。这个找了半天都没有找到,最后咨询的他们官方技术人员才解答。

这里用的是体验版,期限3个月