现在项目有个需求,要求把ms office和txt在线播放,偶当时就想到了布丁网 然后就问……google…… 结果google告诉偶,简单的办法在windows上是可以实现的,非常简单...不过

本文主要是介绍现在项目有个需求,要求把ms office和txt在线播放,偶当时就想到了布丁网 然后就问……google…… 结果google告诉偶,简单的办法在windows上是可以实现的,非常简单...不过,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

现在项目有个需求,要求把ms office和txt在线播放,偶当时就想到了 布丁网

然后就问……google……

结果google告诉偶,简单的办法在windows上是可以实现的,非常简单...不过要用到jacob,具体大家去问Google。
由于要调用dll,在linux上偶不清楚能不能用(公司搞服务器的人说不可以),结果就被pass了……


再然后……只有这么办了……
先用 openOffice把ppt、word、excel、txt转换成pdf,然后用 swftools转换成swf,然后在线播放。

具体说明如下(windows,在linux下偶正准备测试)
1、安装相关软件,这个偶就不说了……
2、下载 jodconverter,偶用的2.2.2...然后怎么把lib放在环境变量或者项目环境偶就不说了……
3、以cmd方式启动openoffice server
Java代码   收藏代码
  1. cd opeonofiice的安装路径/program  

Java代码   收藏代码
  1. soffice -headless -accept="socket,host=127.0.0.1,port=8100;urp;" -nofirststartwizard  

4、看看8100被监听没
Java代码   收藏代码
  1. netstat -an  

5、写代码了……偶没有把代码集成到项目中,所以是单独的例子,不过这样还好点,不然和项目偶和太厉害了
JOD4DocToPDF
Java代码   收藏代码
  1. /** 
  2.  *  
  3.  */  
  4. package com.born.sys.util.pdf;  
  5.   
  6. import java.io.File;  
  7. import java.net.ConnectException;  
  8. import java.util.Date;  
  9.   
  10. import com.artofsolving.jodconverter.DocumentConverter;  
  11. import com.artofsolving.jodconverter.openoffice.connection.OpenOfficeConnection;  
  12. import com.artofsolving.jodconverter.openoffice.connection.SocketOpenOfficeConnection;  
  13. import com.artofsolving.jodconverter.openoffice.converter.OpenOfficeDocumentConverter;  
  14.   
  15. /** 
  16.  * <ul> 
  17.  * <li>文件名称: com.born.sys.util.pdf.JOD4DocToPDF.java</li> 
  18.  * <li>文件描述:</li> 
  19.  * <li>版权所有: 版权所有(C)2001-2006</li> 
  20.  * <li>公 司: born</li> 
  21.  * <li>内容摘要:</li> 
  22.  * <li>其他说明:</li> 
  23.  * <li>完成日期:2010-5-21</li> 
  24.  * <li>修改记录0:无</li> 
  25.  * </ul> 
  26.  *  
  27.  * @version 1.0 
  28.  * @author 许力多 
  29.  */  
  30. public class JOD4DocToPDF extends java.lang.Thread {  
  31.     private File inputFile;// 需要转换的文件  
  32.     private File outputFile;// 输出的文件  
  33.   
  34.     public JOD4DocToPDF(File inputFile, File outputFile) {  
  35.         this.inputFile = inputFile;  
  36.         this.outputFile = outputFile;  
  37.     }  
  38.   
  39.     public void docToPdf() {  
  40.         Date start = new Date();  
  41.         // connect to an OpenOffice.org instance running on port 8100  
  42.         OpenOfficeConnection connection = new SocketOpenOfficeConnection(8100);  
  43.         try {  
  44.             connection.connect();  
  45.   
  46.             // convert  
  47.             DocumentConverter converter = new OpenOfficeDocumentConverter(  
  48.                     connection);  
  49.             converter.convert(inputFile, outputFile);  
  50.         } catch (ConnectException cex) {  
  51.             cex.printStackTrace();  
  52.         } finally {  
  53.             // close the connection  
  54.             if (connection != null) {  
  55.                 connection.disconnect();  
  56.                 connection = null;  
  57.             }  
  58.         }  
  59.         long l = (start.getTime() - new Date().getTime());  
  60.         long day = l / (24 * 60 * 60 * 1000);  
  61.         long hour = (l / (60 * 60 * 1000) - day * 24);  
  62.         long min = ((l / (60 * 1000)) - day * 24 * 60 - hour * 60);  
  63.         long s = (l / 1000 - day * 24 * 60 * 60 - hour * 60 * 60 - min * 60);  
  64.         System.out.println("生成" + outputFile.getName() + "耗费:" + min + "分" + s  
  65.                 + "秒");  
  66.     }  
  67.   
  68.     /** 
  69.      * 由于服务是线程不安全的,所以……需要启动线程 
  70.      */  
  71.     public void run() {  
  72.         this.docToPdf();  
  73.   
  74.     }  
  75.   
  76.     public File getInputFile() {  
  77.         return inputFile;  
  78.     }  
  79.   
  80.     public void setInputFile(File inputFile) {  
  81.         this.inputFile = inputFile;  
  82.     }  
  83.   
  84.     public File getOutputFile() {  
  85.         return outputFile;  
  86.     }  
  87.   
  88.     public void setOutputFile(File outputFile) {  
  89.         this.outputFile = outputFile;  
  90.     }  
  91.   
  92.     /** 
  93.      * @param args 
  94.      */  
  95.     public static void main(String[] args) {  
  96.         JOD4DocToPDF tools = new JOD4DocToPDF(new File("d:/中文的ppt哦.ppt"),  
  97.                 new File("d:/被转换的pdf.pdf"));  
  98.         tools.start();  
  99.   
  100.     }  
  101.   
  102. }  

ps:其实还有很多属性的,不过偶图简单,直接用的官方例子,人懒无敌……阿门

通过Runtime来调用cmd,然后生成相关的播放文件,生成好的flash效果见 点击看效果
PdfToSwf
Java代码   收藏代码
  1. package com.born.sys.util.pdf;  
  2.   
  3. import java.io.BufferedReader;  
  4. import java.io.File;  
  5. import java.io.IOException;  
  6. import java.io.InputStreamReader;  
  7.   
  8. /** 
  9.  * <ul> 
  10.  * <li>文件名称: com.born.sys.util.pdf.PdfToSwf.java</li> 
  11.  * <li>文件描述: pdf生成swf</li> 
  12.  * <li>版权所有: 版权所有(C)2001-2006</li> 
  13.  * <li>公 司: born</li> 
  14.  * <li>内容摘要:</li> 
  15.  * <li>其他说明:</li> 
  16.  * <li>完成日期:2010-5-21</li> 
  17.  * <li>修改记录0:无</li> 
  18.  * </ul> 
  19.  *  
  20.  * @version 1.0 
  21.  * @author 许力多 
  22.  */  
  23. public class PdfToSwf {  
  24.     public int convertPDF2SWF(String sourcePath, String destPath,  
  25.             String fileName) throws IOException {  
  26.         // 目标路径不存在则建立目标路径  
  27.         File dest = new File(destPath);  
  28.         if (!dest.exists()) {  
  29.             dest.mkdirs();  
  30.         }  
  31.   
  32.         // 源文件不存在则返回  
  33.         File source = new File(sourcePath);  
  34.         if (!source.exists()) {  
  35.             return 0;  
  36.         }  
  37.   
  38.         // 调用pdf2swf命令进行转换  
  39.         // D:\tools\SWFTools>pdf2swf.exe -z -B rfxview.swf -s flashversion=9  
  40.         // d:/人员管理系  
  41.         // 统PersonalManagementSystem简介.pdf -o d:/test.swf  
  42.   
  43.         // 要把D:\\tools\\SWFTools\\放在path里面……不然使用不了播放器  
  44.   
  45.         // 先生成flash  
  46.         String[] envp = new String[1];  
  47.         envp[0] = "PATH=D:\\tools\\SWFTools\\";  
  48.         String command = "pdf2swf -z -s flashversion=9 \"" + sourcePath  
  49.                 + "\" -o \"" + destPath + fileName + "\"";  
  50.   
  51.         Process pro = Runtime.getRuntime().exec(command, envp);  
  52.         // System.out.println(command);  
  53.         BufferedReader bufferedReader = new BufferedReader(  
  54.                 new InputStreamReader(pro.getInputStream()));  
  55.         while (bufferedReader.readLine() != null) {  
  56.             String text = bufferedReader.readLine();  
  57.             System.out.println(text);  
  58.         }  
  59.         try {  
  60.             pro.waitFor();  
  61.         } catch (InterruptedException e) {  
  62.             // TODO Auto-generated catch block  
  63.             e.printStackTrace();  
  64.         }  
  65.         // 然后在套播放器  
  66.         /* 
  67.          * swfcombine -z -X 720 -Y 540 "D:\tools\SWFTools\swfs\rfxview.swf" 
  68.          * viewport="d:/人 
  69.          * 员管理系统PersonalManagementSystem简介.swf" -o "d:/人员管理系统PersonalManagemen 
  70.          * tSystem简介.swf" 
  71.          */  
  72.         command = "swfcombine -z -X 720 -Y 540 \"D:/tools/SWFTools/swfs/rfxview.swf\" viewport=\""  
  73.                 + destPath + fileName + "\" -o \"" + destPath + fileName + "\"";  
  74.         pro = Runtime.getRuntime().exec(command, envp);  
  75.         System.out.println(command);  
  76.         bufferedReader = new BufferedReader(new InputStreamReader(pro  
  77.                 .getInputStream()));  
  78.         while (bufferedReader.readLine() != null) {  
  79.             String text = bufferedReader.readLine();  
  80.             System.out.println(text);  
  81.         }  
  82.         try {  
  83.             pro.waitFor();  
  84.         } catch (InterruptedException e) {  
  85.             // TODO Auto-generated catch block  
  86.             e.printStackTrace();  
  87.         }  
  88.         return pro.exitValue();  
  89.   
  90.     }  
  91.   
  92.     public static void main(String[] args) {  
  93.         String sourcePath = "d:/PersonalManagementSystem.pdf";  
  94.         String destPath = "d:/";  
  95.         String fileName = "PersonalManagementSystem.swf";  
  96.         try {  
  97.             System.out.println(new PdfToSwf().convertPDF2SWF(sourcePath,  
  98.                     destPath, fileName));  
  99.         } catch (IOException e) {  
  100.             // TODO Auto-generated catch block  
  101.             e.printStackTrace();  
  102.         }  
  103.     }  

这篇关于现在项目有个需求,要求把ms office和txt在线播放,偶当时就想到了布丁网 然后就问……google…… 结果google告诉偶,简单的办法在windows上是可以实现的,非常简单...不过的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/223661

相关文章

Nginx实现高并发的项目实践

《Nginx实现高并发的项目实践》本文主要介绍了Nginx实现高并发的项目实践,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧... 目录使用最新稳定版本的Nginx合理配置工作进程(workers)配置工作进程连接数(worker_co

python中列表list切分的实现

《python中列表list切分的实现》列表是Python中最常用的数据结构之一,经常需要对列表进行切分操作,本文主要介绍了python中列表list切分的实现,文中通过示例代码介绍的非常详细,对大家... 目录一、列表切片的基本用法1.1 基本切片操作1.2 切片的负索引1.3 切片的省略二、列表切分的高

基于Python实现一个PDF特殊字体提取工具

《基于Python实现一个PDF特殊字体提取工具》在PDF文档处理场景中,我们常常需要针对特定格式的文本内容进行提取分析,本文介绍的PDF特殊字体提取器是一款基于Python开发的桌面应用程序感兴趣的... 目录一、应用背景与功能概述二、技术架构与核心组件2.1 技术选型2.2 系统架构三、核心功能实现解析

使用Python实现表格字段智能去重

《使用Python实现表格字段智能去重》在数据分析和处理过程中,数据清洗是一个至关重要的步骤,其中字段去重是一个常见且关键的任务,下面我们看看如何使用Python进行表格字段智能去重吧... 目录一、引言二、数据重复问题的常见场景与影响三、python在数据清洗中的优势四、基于Python的表格字段智能去重

Spring AI集成DeepSeek实现流式输出的操作方法

《SpringAI集成DeepSeek实现流式输出的操作方法》本文介绍了如何在SpringBoot中使用Sse(Server-SentEvents)技术实现流式输出,后端使用SpringMVC中的S... 目录一、后端代码二、前端代码三、运行项目小天有话说题外话参考资料前面一篇文章我们实现了《Spring

Nginx中location实现多条件匹配的方法详解

《Nginx中location实现多条件匹配的方法详解》在Nginx中,location指令用于匹配请求的URI,虽然location本身是基于单一匹配规则的,但可以通过多种方式实现多个条件的匹配逻辑... 目录1. 概述2. 实现多条件匹配的方式2.1 使用多个 location 块2.2 使用正则表达式

jdk21下载、安装详细教程(Windows、Linux、macOS)

《jdk21下载、安装详细教程(Windows、Linux、macOS)》本文介绍了OpenJDK21的下载地址和安装步骤,包括Windows、Linux和macOS平台,下载后解压并设置环境变量,最... 目录1、官网2、下载openjdk3、安装4、验证1、官网官网地址:OpenJDK下载地址:Ar

使用Apache POI在Java中实现Excel单元格的合并

《使用ApachePOI在Java中实现Excel单元格的合并》在日常工作中,Excel是一个不可或缺的工具,尤其是在处理大量数据时,本文将介绍如何使用ApachePOI库在Java中实现Excel... 目录工具类介绍工具类代码调用示例依赖配置总结在日常工作中,Excel 是一个不可或缺的工http://

Java8需要知道的4个函数式接口简单教程

《Java8需要知道的4个函数式接口简单教程》:本文主要介绍Java8中引入的函数式接口,包括Consumer、Supplier、Predicate和Function,以及它们的用法和特点,文中... 目录什么是函数是接口?Consumer接口定义核心特点注意事项常见用法1.基本用法2.结合andThen链

SpringBoot实现导出复杂对象到Excel文件

《SpringBoot实现导出复杂对象到Excel文件》这篇文章主要为大家详细介绍了如何使用Hutool和EasyExcel两种方式来实现在SpringBoot项目中导出复杂对象到Excel文件,需要... 在Spring Boot项目中导出复杂对象到Excel文件,可以利用Hutool或EasyExcel