国产linux系统(银河麒麟,统信uos)使用 PageOffice 在线打开Word文件最简单集成代码

本文描述了PageOffice产品在(VUE+Springboot)前后端分离的项目中如何集成调用。

假设开发环境电脑IP为:

192.168.1.100

后端Springboot项目

  1. 新建Springboot后端项目:springboot-back,在配置文件application.properties中设置项目端口为:8081

    server.port=8081

  2. 在您项目的pom.xml中通过下面的代码引入PageOffice依赖。pageoffice.jar已发布到Maven中央仓库,建议使用最新版本。

如果使用Tomcat10及以上版本,使用下面的pom.xml配置

<dependency>
  <groupId>com.zhuozhengsoft</groupId>   
  <artifactId>pageoffice</artifactId>   
  <version>6.3.2.2</version>
</dependency>

如果使用Tomcat9及以下的版本,使用下面的pom.xml配置

<dependency>
  <groupId>com.zhuozhengsoft</groupId>   
  <artifactId>pageoffice</artifactId>   
  <version>6.3.2.2-javax</version>
</dependency>
  1. 新建一个pageoffice文件夹,用来存放PageOffice的系统文件(如license.lic、客户端安装包等),比如windows环境下创建:D:/pageoffice,linux环境下创建:/root/pageoffice
  2. 拷贝pageoffice客户端安装程序到上一步创建的pageoffice文件夹下。
  • 客户端是windows环境:拷贝posetup_6.3.2.2.exe到pageoffice文件夹下;

  • 客户端是国产操作系统环境:拷贝对应芯片的PageOffice客户端deb安装包到pageoffice文件夹下;

PageOffice客户端安装程序下载地址:https://gitee.com/pageoffice/pageoffice6-client/releases

  1. 打开springboot-back项目的配置文件application.properties,添加一个posyspath变量,值为上一步创建的pageoffice文件夹的路径

    server.port=8081
    posyspath=D:/pageoffice

  2. 在您项目的启动类Application类中添加一项@Bean配置,此为PageOffice服务器端的必要配置,代码如下:

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

    @Bean
    public ServletRegistrationBean pageofficeRegistrationBean() {
    com.zhuozhengsoft.pageoffice.poserver.Server poserver
    = new com.zhuozhengsoft.pageoffice.poserver.Server();
    poserver.setSysPath(poSysPath);//设置PageOffice注册成功后,license.lic文件存放的目录

    ServletRegistrationBean srb = new ServletRegistrationBean(poserver);
    srb.addUrlMappings("/poserver.zz");
    srb.addUrlMappings("/poclient");
    srb.addUrlMappings("/sealsetup.exe");
    return srb;
    }

注意:在实际开发中,您的后端项目中必须将PageOffice相关配置请求从后端拦截器SpringSecurity或者Shiro等授权认证校验框架中放出来。例如:

  • SpringSecurity

    antMatchers("/poserver.zz","/poclient","/sealsetup.exe").permitAll()

  • Shiro

    filterChainDefinitionMap.put("/poserver.zz", "anon");
    filterChainDefinitionMap.put("/poclient", "anon");
    filterChainDefinitionMap.put("/sealsetup.exe", "anon");

  1. 新建Controller并调用PageOffice在线打开文件,例如DocumentController代码如下:

    @RestController
    @RequestMapping(value = "/doc")
    public class DocumentController {
    //获取doc目录的磁盘路径
    private String dir = GetDirPathUtil.getDirPath() + "static/";

     @RequestMapping(value="/openFile")
     public String openFile(HttpServletRequest request,int file_id,String file_name)  {
     	//file_id和file_name是为了展示如何使用参数,我们这里只用到了file_name
     	PageOfficeCtrl poCtrl = new PageOfficeCtrl(request);
     	//webOpen的第一个参数支持能够输出下载文件的Url相对地址或者文件在服务器上的磁盘路径两种方式
     	//查看详细,请在"https://www.pageoffice.cn/"搜索"PageOffice属性或方法中涉及到的URL路径或磁盘路径的说明"
     	poCtrl.webOpen("file://"+dir+file_name, OpenModeType.docNormalEdit, "张三");
     	return poCtrl.getHtmlCode();//必须
     }
    
     @RequestMapping("/saveFile")
     public void saveFile(HttpServletRequest request, HttpServletResponse response,int file_id,String file_name)  {
     	//file_id和file_name是为了展示如何使用参数,我们这里只用到了file_name
     	FileSaver fs = new FileSaver(request, response);
     	fs.saveToFile(dir + file_name);
     	fs.close();
     }
    

    }

前端vue项目

  1. 新建Vue前端项目:vue-front

  2. Vue配置代理。

    devServer: {
    proxy: {
    '/dev-api': { // "/dev-api"对应后端项目"http://192.168.1.100:8081"地址
    target: 'http://192.168.1.100:8081',
    ws: true,
    changeOrigin: true,
    pathRewrite: {
    '^/dev-api': ''
    }
    },
    }
    }

  3. 引用js-pageoffice库。

注意:请确保安装的js-pageoffice库版本号与后端项目pom.xml文件中引用的PageOffice JAR包版本号的前三位相同。

​ 使用命令安装:npm install js-pageoffice@6.3.1 --save-exact

  1. 在全局拦截器中添加PageOffice相关配置。

    import axios from "axios";
    import { POBrowser } from "js-pageoffice";

    // 创建 axios 实例
    const service = axios.create({
    baseURL: "/dev-api", // 设置你的基础 URL
    timeout: 5000, // 设置请求超时时间
    });
    // 请求拦截器
    service.interceptors.request.use(
    (config) => {
    // 在发送请求之前做些什么
    //const token = Cookies.get('token'); // 假设你的token存储在cookie中
    const token = "123";
    if (token) {
    config.headers["Authorization"] = "Bearer " + token; // 将token添加到请求头中
    // PageOffice全局配置,必须在此拦截器中定义
    //必须。设置后端代理,具体属性值以您实际开发为准,比如POBrowser.setProxyBaseAPI(process.env.VUE_APP_BASE_API);
    POBrowser.setProxyBaseAPI("/dev-api");
    //必须。向PageOffice后端请求设置header,支持多次调用setHeader()设置更多的值,具体属性名称和属性值以您实际开发为准。
    POBrowser.setHeader("Authorization", "Bearer " + token);
    /**
    * 前端存储token的方案
    *方案1.使用Cookie
    *如果您的令牌(token)存储在Cookie中,PageOffice会默认支持通过Cookie方式保存令牌,因此您无需编写任何额外的代码。
    *方案2.使用Localstorage或者SessionStorage
    *如果令牌(token)是保存在LocalStorage或SessionStorage中,您必须调用POBrowser.setStorage()方法。
    */
    //POBrowser.setStorage("Admin-Token",getToken());//支持多次调用setStorage()设置更多的值,具体属性名称和属性值以您实际开发为准。
    }

     return config;
    

    },
    (error) => {
    // 对请求错误做些什么
    return Promise.reject(error);
    }
    );

  2. 新建一个Vue页面:src/views/DocView.vue,用来显示在线打开的文档。

    <template>
    演示: 文档

    </template> <script> import request from '@/utils/request' export default { name: 'DocView', data() { return { poHtmlCode: '', open_params: '', } }, created: function () { //使用pageofficectrl.WindowParams获取获取父页面(此项目中为:HomeView.vue)中POBrowser.openWindow()方法的第三个参数的值,获取到的值为string类型 this.open_params = JSON.parse(pageofficectrl.WindowParams); // 请求后端打开文件 this.openFile().then(response => { this.poHtmlCode = response; } );
    },
    methods: {
      OnPageOfficeCtrlInit() {
        //PageOffice的初始化事件回调函数,您可以在这里添加自定义按钮
        pageofficectrl.AddCustomToolButton("保存", "Save", 1);//其中"Save"对应methods中的Save()函数,并且需要在mounted中挂载。
      },
      Save() {
        //使用SaveFilePage属性设置后端保存方法的Controller路由地址,这个地址必须从"/"开始,并且也可以向此路由地址传递json字符串参数,示例如下:
        let saveFileUrl = "/doc/saveFile";
        let paramValue = new URLSearchParams(this.open_params);//为了简单起见,这里直接使用打开时的参数。
        pageofficectrl.SaveFilePage = `${saveFileUrl}?${paramValue.toString()}`;
        //在这里写您保存前的代码
        pageofficectrl.WebSave();
        //在这里写您保存后的代码,比如判断保存结果pageofficectrl.CustomSaveResult
        //alert(pageofficectrl.CustomSaveResult);
      },
      AfterDocumentOpened() {
        //在这里写您文档打开后自动触发的代码
      },
      openFile() {
        //发起GET请求到后端Controller的/doc/openFile路由
        return request({
          url: '/doc/openFile',
          method: 'get',
          params: this.open_params
        })
      }
    },
    mounted: function () {
      //将当前页面methods中定义的函数挂载到PageOffice控件,例如控件触发的事件、自定义按钮触发的函数。
      window.POPageMounted = this;//此行必须
    }
    

    }
    </script>

  3. 配置DocView.vue的访问路由。

    const routes = [
    // 其他路由配置项...
    // 下面添加DocView.vue的路由
    ,
    {
    path: '/showDoc',
    name: 'doc',
    component: () => import('../views/DocView.vue')
    }
    ]

  4. 在您的Vue页面(比如HomeView.vue,PageOffice中把这个页面称之为父页面)添加一个打开文件的超链接,点击超链接调用POBrowser对象的openWindow方法,弹出PageOffice浏览器(POBrowser)窗口访问DocView.vue在线打开文件,代码如下:

    <a href="#" @click.prevent="open_pageoffice()">打开文件

    <script> import request from '@/utils/request' import { POBrowser } from 'js-pageoffice' export default { name: 'HomeView', methods: { open_pageoffice() { let paramJson={}; paramJson.file_id=1; paramJson.file_name="test.doc"; let paramString=JSON.stringify(paramJson);
       //openWindow()第三个参数用来向弹出的PageOffice浏览器(POBrowser)窗口传递参数(参数长度不限),支持json格式字符串。
       //此处为了方便演示,我们传递了file_id和file_name两个参数,具体以您实际开发为准。
       POBrowser.openWindow('/showDoc', 'width=1150px;height=900px;',paramString);
     },
    

    }
    }
    </script>

  5. 启动springboot-back和vue-front项目,点击"打开文件"超链接,查看在线打开编辑保存Word文件的效果。

参考链接:PageOffice最简集成代码(VUE+Springboot)

相关推荐
AiFlutter11 分钟前
Java实现简单的搜索引擎
java·搜索引擎·mybatis
飞升不如收破烂~31 分钟前
Spring boot常用注解和作用
java·spring boot·后端
秦老师Q32 分钟前
Java基础第九章-Java集合框架(超详细)!!!
java·开发语言
计算机毕设源码qq-383653104133 分钟前
(附项目源码)Java开发语言,215 springboot 大学生爱心互助代购网站,计算机毕设程序开发+文案(LW+PPT)
java·开发语言·spring boot·mysql·课程设计
ashane131436 分钟前
Java list
java·windows·list
袁庭新43 分钟前
Cannal实现MySQL主从同步环境搭建
java·数据库·mysql·计算机·java程序员·袁庭新
无尽的大道44 分钟前
深入理解 Java 阻塞队列:使用场景、原理与性能优化
java·开发语言·性能优化
万里沧海寄云帆1 小时前
Word 插入分节符页码更新问题
windows·microsoft·word
岁岁岁平安1 小时前
springboot实战(15)(注解@JsonFormat(pattern=“?“)、@JsonIgnore)
java·spring boot·后端·idea
Oak Zhang1 小时前
TheadLocal出现的内存泄漏具体泄漏的是什么?弱引用在里面有什么作用?什么情景什么问题?
java·系统安全