首页 > 其他分享 >[原创]PageOffice最简集成代码(VUE3+Springboot)

[原创]PageOffice最简集成代码(VUE3+Springboot)

时间:2024-12-09 09:12:38浏览次数:8  
标签:最简 Springboot pageoffice token POBrowser file PageOffice name

转自:https://pageoffice.cn/pages/1c2c6e/
本文描述了PageOffice产品在(VUE3+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.3.1</version>
</dependency>

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

<dependency>
  <groupId>com.zhuozhengsoft</groupId>   
  <artifactId>pageoffice</artifactId>   
  <version>6.3.3.1-javax</version>
</dependency>
  1. 新建一个pageoffice文件夹,用来存放PageOffice的系统文件(如license.lic、客户端安装包等),比如windows环境下创建:D:/pageoffice,linux环境下创建:/root/pageoffice

  2. 拷贝pageoffice客户端安装程序到上一步创建的pageoffice文件夹下。

    • 客户端是windows环境:拷贝posetup_6.3.3.1.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
  1. 在您项目的启动类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;
}

::: warning
注意:在实际开发中,您的后端项目中必须将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");

:::
7. 新建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.getHtml();//必须
	}

	@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();
	}
}

前端vue3项目

  1. 新建Vue3前端项目: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,用来显示在线打开的文档。

     <script setup>
     import request from '@/utils/request';
     import { ref, onMounted } from 'vue'
    
     const poHtmlCode = ref('');
     const open_params = ref('');
    
     function OnPageOfficeCtrlInit() {
       // PageOffice的初始化事件回调函数,您可以在这里添加自定义按钮
       pageofficectrl.AddCustomToolButton("保存", "Save", 1);//其中"Save"对应function Save()函数,并且需要在onMounted中挂载。
     };
    
     function Save() {
       //使用SaveFilePage属性设置后端保存方法的Controller路由地址,这个地址必须从"/"开始,并且也可以向此路由地址传递json字符串参数,示例如下:
       let saveFileUrl = "/doc/saveFile";
       let paramValue = new URLSearchParams(open_params.value);//为了简单起见,这里直接使用打开时的参数。
       pageofficectrl.SaveFilePage = `${saveFileUrl}?${paramValue.toString()}`;
       //在这里写您保存前的代码
       pageofficectrl.WebSave();
       //在这里写您保存后的代码,比如判断保存结果pageofficectrl.CustomSaveResult
       //alert(pageofficectrl.CustomSaveResult);
     };
    
     function AfterDocumentOpened() {
       //在这里写您文档打开后自动触发的代码
     };
    
     function openFile() {
       // 发起GET请求到后端Controller的/doc/openFile路由
       return request({
         url: '/doc/openFile',
         method: 'get',
         params: open_params.value
       });
     };
    
     onMounted(() => {
       //使用pageofficectrl.WindowParams获取获取父页面(此项目中为:HomeView.vue)中POBrowser.openWindow()方法的第三个参数的值,获取到的值为string类型
       open_params.value = JSON.parse(pageofficectrl.WindowParams);
       // 请求后端打开文件
       openFile().then(response => {
         poHtmlCode.value = response;
       });
       //将需要回调的函数挂载到PageOffice控件,例如控件触发的事件、自定义按钮触发的函数。
       window.POPageMounted = { OnPageOfficeCtrlInit, AfterDocumentOpened, Save };//其中OnPageOfficeCtrlInit必须
    
     });
     </script>
     <template>
       <div class="doc">
         演示: 文档<br /><br />
         <!-- 此div用来加载PageOffice客户端控件,其中div的高宽及位置就决定了控件的大小及位置 -->
         <div style="width:auto; height:900px;" v-html="poHtmlCode"></div>
       </div>
     </template>
    
  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()">打开文件</a>
    
     <script setup>
     import request from '@/utils/request';
     import { POBrowser } from "js-pageoffice";
     import { ref, onMounted } from 'vue';
    
     const titleText = ref('');
     const paramJson = {};
     paramJson.file_id = 1;
     paramJson.file_name = "test.doc";
     const paramString = JSON.stringify(paramJson);
    
     function open_pageoffice() {
       //openWindow()第三个参数用来向弹出的PageOffice浏览器(POBrowser)窗口传递参数(参数长度不限),支持json格式字符串。
       //此处为了方便演示,我们传递了file_id和file_name两个参数,具体以您实际开发为准。
       POBrowser.openWindow('/showDoc', 'width=1150px;height=900px;', paramString);
    
     }
     </script>
    
  5. 启动springboot-back和vue-front项目,点击“打开文件”超链接,查看在线打开编辑保存Word文件的效果。

标签:最简,Springboot,pageoffice,token,POBrowser,file,PageOffice,name
From: https://www.cnblogs.com/pageoffice/p/18594174

相关文章

  • 【含开题报告+文档+PPT+源码】基于SpringBoot+Vue的高校食堂外包管理系统的设计与实现
    开题报告随着高校后勤服务社会化改革的持续推进,食堂作为高校后勤服务的重要组成部分,其服务质量和管理水平直接关系到学生的日常生活质量和校园的整体形象。传统的食堂管理模式往往存在诸多问题,如菜品单一、服务质量不高、管理效率低下等,难以满足师生对餐饮服务的高品质需求。......
  • 【含开题报告+文档+PPT+源码】基于SpringBoot+Vue的汽车展销平台的设计与实现
    开题报告随着全球环保意识的日益增强以及能源结构的转型,汽车行业得以迅猛发展。汽车,特别是电动汽车,以其零排放、低能耗和高效能等特点,逐渐受到各国政府、企业和消费者的青睐。然而,汽车市场的快速发展也带来了诸多挑战,其中最为突出的问题之一就是销售管理。传统的汽车销售管理......
  • 【开题报告+论文+源码】基于SpringBoot+Vue的火锅食材销售网站的设计与实现
    项目背景与意义首先,设计与实现火锅食材销售网站具有重要的现实意义。火锅作为我国传统美食,拥有庞大的消费群体。然而,在传统购物方式中,消费者往往需要亲自前往市场选购食材,费时费力。此外,由于市场信息不对称,消费者很难掌握火锅食材的价格、质量等信息,容易导致购买到不满意的商......
  • 【开题报告+论文+源码】基于SpringBoot+Vue的猫咪商城管理系统
    项目背景与意义随着社会经济的发展和生活水平的提高,人们对精神生活的需求日益增长,宠物尤其是猫咪因其温顺可爱、独立优雅的特性,深受现代都市人群的喜爱。与此同时,以猫咪为主题的休闲娱乐场所——猫咖,作为一种新型社交空间应运而生,逐渐成为人们放松身心、交流互动的重要场所。......
  • springboot空巢老人健康管理系统小程序-计算机毕业设计源码29889
    摘 要随着社会老龄化程度不断加剧,空巢老人群体的健康管理问题日益引起人们的关注。为了更好地满足空巢老人群体的健康管理需求,本研究致力于设计并实现一款基于SpringBoot框架的空巢老人健康管理系统。该系统旨在为管理员用户、老人用户和医生用户提供全方位的健康管理服务......
  • springboot玩具回收与租借系统-计算机毕业设计源码47829
    目 录摘要1绪论1.1研究背景1.2课题意义2 玩具回收与租借系统系统分析2.1可行性分析2.1.1技术可行性分析2.1.2经济可行性分析2.1.3法律可行性分析2.2系统功能分析2.2.1功能性分析2.2.2非功能性分析2.3系统用例分析2.4系统流程分析2......
  • springboot毕设 失踪人口信息安全管理系统 程序+论文
    本系统(程序+源码)带文档lw万字以上文末可获取一份本项目的java源码和数据库参考。系统程序文件列表开题报告内容研究背景在当今社会,随着人口流动性的增加和社会环境的复杂化,失踪人口问题日益凸显,成为社会关注的焦点之一。失踪人口的增加不仅给家庭带来无尽的痛苦,也给社会......
  • springboot毕设 水果蔬菜商城 程序+论文
    本系统(程序+源码)带文档lw万字以上文末可获取一份本项目的java源码和数据库参考。系统程序文件列表开题报告内容研究背景随着互联网的飞速发展,电子商务已成为现代商业的重要组成部分,深刻改变了人们的购物方式。在快节奏的生活中,消费者越来越倾向于通过线上平台购买日常所......
  • springboot毕设基于Springboot服装搭配系统源码+论文+部署
    本系统(程序+源码)带文档lw万字以上 文末可获取一份本项目的java源码和数据库参考。系统程序文件列表开题报告内容一、研究背景随着人们生活水平的提高,对于服装的需求不再仅仅局限于蔽体保暖,时尚和个性化穿搭成为人们关注的重点。在当今数字化时代,服装行业也在积极寻求与信......
  • springboot毕设基于Java的教材征订系统源码+论文+部署
    本系统(程序+源码)带文档lw万字以上 文末可获取一份本项目的java源码和数据库参考。系统程序文件列表开题报告内容一、研究背景、意义、目的(一)研究背景在现代教育体系中,教材的征订管理是一项复杂且重要的工作。随着学校规模的扩大、课程种类的增多以及学生人数的增长,传统......