Java+FlexPaper+swfTools仿百度文库文档在线预览系统设计与实现

转载于:http://blog.csdn.net/hil2000/article/details/8459940,作者:hil2000

 

笔者最近在给客户开发文档管理系统时,客户要求上传到管理系统的文档(包括ppt,word,excel,txt)只能预览不允许下载。笔者想到了百度文库和豆丁网,百度文库和豆丁网的在线预览都是利用flash来播放文档的,在网上查阅了大量资料,终于实现了该项功能,现将自己的设计和实现整理如下。

一、如何将文档转成flash支持的swf文件实现在线播放?
1.先用openOffice把ppt、word、excel、txt类型的文档转换成pdf
2.用swftools将pdf转换成swf,然后利用FlexPaper插件实现在线播放预览。
二、具体实现
1.安装必备工具组件
(1)安装openoffice,openoffice是开源免费的文字处理软件,它可以将office文档转成pdf文件(笔者安装到D:\ProgramFiles),openOffice下载地址http://www.openoffice.org/download/index.html
(2)安装完openoffice后必须启动其server,以命令行方式启动openoffice server。进入cmd命令行提示符D:\Program Files\OpenOffice.org 3\program\
键入如下命令:
soffice -headless -accept="socket,host=127.0.0.1,port=8100;urp;" –nofirststartwizard
Java+FlexPaper+swfTools仿百度文库文档在线预览系统设计与实现_第1张图片
进入windows任务管理器查看有个进程soffice.bin,说明openoffice启动成功!
Java+FlexPaper+swfTools仿百度文库文档在线预览系统设计与实现_第2张图片
(3)安装swfTools(安装到 D:\Program Files)swftools作用是将pdf转换为swf文件以便flexpaper播放。下载地址:http://www.swftools.org/download.html
(4)下载flexpaper,下载地址:http://flexpaper.devaldi.com/download/
笔者下载的是FlexPaper_1.5.1,下载后将其解压备用。
(5)下载OpenDocument文档转换器 JODConverter,JODConverter是一个java的OpenDucument文件转换器,可以进行许多文件格式的转换,它利用OpenOffice来进行转换工作,它能进行以下的转换工作:
a.Microsoft Office格式转换为OpenDucument,以及OpenDucument转换为Microsoft Office
b.OpenDucument转换为PDF,Word、Excel、PowerPoint转换为PDF,RTF转换为PDF等。
下载地址:http://sourceforge.net/projects/jodconverter/files/
我们后面开发主要用它的jodconverter-2.2.2.jar包

2.软件开发过程
(1)启动Eclipse,新建web项目名称为ctcesims
(2)将上面第4步解压的flexpaper文件中的js文件夹(包含了flexpaper_flash_debug.js,flexpaper_flash.js,jquery.js,这三个js文件主要是预览swf文件的插件)拷贝至网站根目录;将FlexPaperViewer.swf拷贝至网站根目录下(该文件主要是用在网页中播放swf文件的播放器),目录结构如下图
Java+FlexPaper+swfTools仿百度文库文档在线预览系统设计与实现_第3张图片
(3)创建documentUpload.jsp文件

[html] view plain copy
 
  1. <%@pagelanguage="java"contentType="text/html;charset=UTF-8"
  2. pageEncoding="UTF-8"%>
  3. <!DOCTYPEhtmlPUBLIC"-//W3C//DTDHTML4.01Transitional//EN""http://www.w3.org/TR/html4/loose.dtd">
  4. <html>
  5. <head>
  6. <metahttp-equiv="Content-Type"content="text/html;charset=UTF-8">
  7. <title>文档在线预览系统</title>
  8. <style>
  9. body{margin-top:100px;background:#fff;font-family:Verdana,Tahoma;}
  10. a{color:#CE4614;}
  11. #msg-box{color:#CE4614;font-size:0.9em;text-align:center;}
  12. #msg-box.logo{border-bottom:5pxsolid#ECE5D9;margin-bottom:20px;padding-bottom:10px;}
  13. #msg-box.title{font-size:1.4em;font-weight:bold;margin:0030px0;}
  14. #msg-box.nav{margin-top:20px;}
  15. </style>
  16. </head>
  17. <body>
  18. <divid="msg-box">
  19. <formname="form1"method="post"enctype="multipart/form-data"action="docUploadConvertAction.jsp">
  20. <divclass="title">
  21. 请上传要处理的文件,过程可能需要几分钟,请稍候片刻。
  22. </div>
  23. <p>
  24. <inputname="file1"type="file">
  25. </p>
  26. <p>
  27. <inputtype="submit"name="Submit"value="上传">
  28. </p>
  29. </form>
  30. </div>
  31. </body>
  32. </html>

(4)创建文档转换类DocConverter.java

[java] view plain copy
 
  1. packagecom.cectsims.util;
  2. importjava.io.BufferedInputStream;
  3. importjava.io.File;
  4. importjava.io.IOException;
  5. importjava.io.InputStream;
  6. importcom.artofsolving.jodconverter.DocumentConverter;
  7. importcom.artofsolving.jodconverter.openoffice.connection.OpenOfficeConnection;
  8. importcom.artofsolving.jodconverter.openoffice.connection.SocketOpenOfficeConnection;
  9. importcom.artofsolving.jodconverter.openoffice.converter.OpenOfficeDocumentConverter;
  10. /**
  11. *docdocx格式转换
  12. */
  13. publicclassDocConverter{
  14. privatestaticfinalintenvironment=1;//环境1:windows2:linux
  15. privateStringfileString;//(只涉及pdf2swf路径问题)
  16. privateStringoutputPath="";//输入路径,如果不设置就输出在默认的位置
  17. privateStringfileName;
  18. privateFilepdfFile;
  19. privateFileswfFile;
  20. privateFiledocFile;
  21. publicDocConverter(StringfileString){
  22. ini(fileString);
  23. }
  24. /**
  25. *重新设置file
  26. *
  27. *@paramfileString
  28. */
  29. publicvoidsetFile(StringfileString){
  30. ini(fileString);
  31. }
  32. /**
  33. *初始化
  34. *
  35. *@paramfileString
  36. */
  37. privatevoidini(StringfileString){
  38. this.fileString=fileString;
  39. fileName=fileString.substring(0,fileString.lastIndexOf("."));
  40. docFile=newFile(fileString);
  41. pdfFile=newFile(fileName+".pdf");
  42. swfFile=newFile(fileName+".swf");
  43. }
  44. /**
  45. *转为PDF
  46. *
  47. *@paramfile
  48. */
  49. privatevoiddoc2pdf()throwsException{
  50. if(docFile.exists()){
  51. if(!pdfFile.exists()){
  52. OpenOfficeConnectionconnection=newSocketOpenOfficeConnection(8100);
  53. try{
  54. connection.connect();
  55. DocumentConverterconverter=newOpenOfficeDocumentConverter(connection);
  56. converter.convert(docFile,pdfFile);
  57. //closetheconnection
  58. connection.disconnect();
  59. System.out.println("****pdf转换成功,PDF输出:"+pdfFile.getPath()+"****");
  60. }catch(java.net.ConnectExceptione){
  61. e.printStackTrace();
  62. System.out.println("****swf转换器异常,openoffice服务未启动!****");
  63. throwe;
  64. }catch(com.artofsolving.jodconverter.openoffice.connection.OpenOfficeExceptione){
  65. e.printStackTrace();
  66. System.out.println("****swf转换器异常,读取转换文件失败****");
  67. throwe;
  68. }catch(Exceptione){
  69. e.printStackTrace();
  70. throwe;
  71. }
  72. }else{
  73. System.out.println("****已经转换为pdf,不需要再进行转化****");
  74. }
  75. }else{
  76. System.out.println("****swf转换器异常,需要转换的文档不存在,无法转换****");
  77. }
  78. }
  79. /**
  80. *转换成swf
  81. */
  82. @SuppressWarnings("unused")
  83. privatevoidpdf2swf()throwsException{
  84. Runtimer=Runtime.getRuntime();
  85. if(!swfFile.exists()){
  86. if(pdfFile.exists()){
  87. if(environment==1){//windows环境处理
  88. try{
  89. Processp=r.exec("D:/ProgramFiles/SWFTools/pdf2swf.exe"+pdfFile.getPath()+"-o"+swfFile.getPath()+"-T9");
  90. System.out.print(loadStream(p.getInputStream()));
  91. System.err.print(loadStream(p.getErrorStream()));
  92. System.out.print(loadStream(p.getInputStream()));
  93. System.err.println("****swf转换成功,文件输出:"
  94. +swfFile.getPath()+"****");
  95. if(pdfFile.exists()){
  96. pdfFile.delete();
  97. }
  98. }catch(IOExceptione){
  99. e.printStackTrace();
  100. throwe;
  101. }
  102. }elseif(environment==2){//linux环境处理
  103. try{
  104. Processp=r.exec("pdf2swf"+pdfFile.getPath()
  105. +"-o"+swfFile.getPath()+"-T9");
  106. System.out.print(loadStream(p.getInputStream()));
  107. System.err.print(loadStream(p.getErrorStream()));
  108. System.err.println("****swf转换成功,文件输出:"
  109. +swfFile.getPath()+"****");
  110. if(pdfFile.exists()){
  111. pdfFile.delete();
  112. }
  113. }catch(Exceptione){
  114. e.printStackTrace();
  115. throwe;
  116. }
  117. }
  118. }else{
  119. System.out.println("****pdf不存在,无法转换****");
  120. }
  121. }else{
  122. System.out.println("****swf已经存在不需要转换****");
  123. }
  124. }
  125. staticStringloadStream(InputStreamin)throwsIOException{
  126. intptr=0;
  127. in=newBufferedInputStream(in);
  128. StringBufferbuffer=newStringBuffer();
  129. while((ptr=in.read())!=-1){
  130. buffer.append((char)ptr);
  131. }
  132. returnbuffer.toString();
  133. }
  134. /**
  135. *转换主方法
  136. */
  137. @SuppressWarnings("unused")
  138. publicbooleanconver(){
  139. if(swfFile.exists()){
  140. System.out.println("****swf转换器开始工作,该文件已经转换为swf****");
  141. returntrue;
  142. }
  143. if(environment==1){
  144. System.out.println("****swf转换器开始工作,当前设置运行环境windows****");
  145. }else{
  146. System.out.println("****swf转换器开始工作,当前设置运行环境linux****");
  147. }
  148. try{
  149. doc2pdf();
  150. pdf2swf();
  151. }catch(Exceptione){
  152. e.printStackTrace();
  153. returnfalse;
  154. }
  155. if(swfFile.exists()){
  156. returntrue;
  157. }else{
  158. returnfalse;
  159. }
  160. }
  161. /**
  162. *返回文件路径
  163. *
  164. *@params
  165. */
  166. publicStringgetswfPath(){
  167. if(swfFile.exists()){
  168. StringtempString=swfFile.getPath();
  169. tempString=tempString.replaceAll("\\\\","/");
  170. returntempString;
  171. }else{
  172. return"";
  173. }
  174. }
  175. /**
  176. *设置输出路径
  177. */
  178. publicvoidsetOutputPath(StringoutputPath){
  179. this.outputPath=outputPath;
  180. if(!outputPath.equals("")){
  181. StringrealName=fileName.substring(fileName.lastIndexOf("/"),
  182. fileName.lastIndexOf("."));
  183. if(outputPath.charAt(outputPath.length())=='/'){
  184. swfFile=newFile(outputPath+realName+".swf");
  185. }else{
  186. swfFile=newFile(outputPath+realName+".swf");
  187. }
  188. }
  189. }
  190. }

(5)创建文档上传转换处理文件docUploadConvertAction.jsp文件

[html] view plain copy
 
  1. <%@pagelanguage="java"contentType="text/html;charset=UTF-8"
  2. pageEncoding="UTF-8"%>
  3. <%@pageimport="java.io.*"%>
  4. <%@pageimport="java.util.Enumeration"%>
  5. <%@pageimport="com.oreilly.servlet.MultipartRequest"%>
  6. <%@pageimport="com.oreilly.servlet.multipart.DefaultFileRenamePolicy"%>
  7. <%@pageimport="com.cectsims.util.DocConverter"%>
  8. <%
  9. //文件上传采用cos组件上传,可更换为commons-fileupload上传,文件上传后,保存在upload文件夹
  10. //获取文件上传路径
  11. StringsaveDirectory=application.getRealPath("/")+"upload";
  12. //打印上传路径信息
  13. System.out.println(saveDirectory);
  14. //每个文件最大50m
  15. intmaxPostSize=50*1024*1024;
  16. //采用cos缺省的命名策略,重名后加1,2,3...如果不加dfp重名将覆盖
  17. DefaultFileRenamePolicydfp=newDefaultFileRenamePolicy();
  18. //response的编码为"UTF-8",同时采用缺省的文件名冲突解决策略,实现上传,如果不加dfp重名将覆盖
  19. MultipartRequestmulti=newMultipartRequest(request,saveDirectory,maxPostSize,"UTF-8",dfp);
  20. //MultipartRequestmulti=newMultipartRequest(request,saveDirectory,maxPostSize,"UTF-8");
  21. //输出反馈信息
  22. Enumerationfiles=multi.getFileNames();
  23. while(files.hasMoreElements()){
  24. System.err.println("ccc");
  25. Stringname=(String)files.nextElement();
  26. Filef=multi.getFile(name);
  27. if(f!=null){
  28. StringfileName=multi.getFilesystemName(name);
  29. //获取上传文件的扩展名
  30. StringextName=fileName.substring(fileName.lastIndexOf(".")+1);
  31. //文件全路径
  32. StringlastFileName=saveDirectory+"\\"+fileName;
  33. //获取需要转换的文件名,将路径名中的'\'替换为'/'
  34. Stringconverfilename=saveDirectory.replaceAll("\\\\","/")+"/"+fileName;
  35. System.out.println(converfilename);
  36. //调用转换类DocConverter,并将需要转换的文件传递给该类的构造方法
  37. DocConverterd=newDocConverter(converfilename);
  38. //调用conver方法开始转换,先执行doc2pdf()将office文件转换为pdf;再执行pdf2swf()将pdf转换为swf;
  39. d.conver();
  40. //调用getswfPath()方法,打印转换后的swf文件路径
  41. System.out.println(d.getswfPath());
  42. //生成swf相对路径,以便传递给flexpaper播放器
  43. Stringswfpath="upload"+d.getswfPath().substring(d.getswfPath().lastIndexOf("/"));
  44. System.out.println(swfpath);
  45. //将相对路径放入sessio中保存
  46. session.setAttribute("swfpath",swfpath);
  47. out.println("上传的文件:"+lastFileName);
  48. out.println("文件类型"+extName);
  49. out.println("<hr>");
  50. }
  51. }
  52. %>
  53. <!DOCTYPEhtmlPUBLIC"-//W3C//DTDHTML4.01Transitional//EN""http://www.w3.org/TR/html4/loose.dtd">
  54. <html>
  55. <head>
  56. <metahttp-equiv="Content-Type"content="text/html;charset=UTF-8">
  57. <title>Inserttitlehere</title>
  58. <style>
  59. body{margin-top:100px;background:#fff;font-family:Verdana,Tahoma;}
  60. a{color:#CE4614;}
  61. #msg-box{color:#CE4614;font-size:0.9em;text-align:center;}
  62. #msg-box.logo{border-bottom:5pxsolid#ECE5D9;margin-bottom:20px;padding-bottom:10px;}
  63. #msg-box.title{font-size:1.4em;font-weight:bold;margin:0030px0;}
  64. #msg-box.nav{margin-top:20px;}
  65. </style>
  66. </head>
  67. <body>
  68. <div>
  69. <formname="viewForm"id="form_swf"action="documnetView.jsp"method="POST">
  70. <inputtype='submit'value='预览'class='BUTTONSUBMIT'/>
  71. </form>
  72. </div>
  73. </body>
  74. </html>

(6)创建文档预览文件documentView.jsp

[html] view plain copy
 
  1. <%@pagelanguage="java"contentType="text/html;charset=UTF-8"
  2. pageEncoding="UTF-8"%>
  3. <%
  4. StringswfFilePath=session.getAttribute("swfpath").toString();
  5. %>
  6. <!DOCTYPEhtmlPUBLIC"-//W3C//DTDHTML4.01Transitional//EN""http://www.w3.org/TR/html4/loose.dtd">
  7. <html>
  8. <head>
  9. <metahttp-equiv="Content-Type"content="text/html;charset=UTF-8">
  10. <scripttype="text/javascript"src="js/jquery.js"></script>
  11. <scripttype="text/javascript"src="js/flexpaper_flash.js"></script>
  12. <scripttype="text/javascript"src="js/flexpaper_flash_debug.js"></script>
  13. <styletype="text/css"media="screen">
  14. html,body{height:100%;}
  15. body{margin:0;padding:0;overflow:auto;}
  16. #flashContent{display:none;}
  17. </style>
  18. <title>文档在线预览系统</title>
  19. </head>
  20. <body>
  21. <divstyle="position:absolute;left:50px;top:10px;">
  22. <aid="viewerPlaceHolder"style="width:820px;height:650px;display:block"></a>
  23. <scripttype="text/javascript">
  24. varfp=newFlexPaperViewer(
  25. 'FlexPaperViewer',
  26. 'viewerPlaceHolder',{config:{
  27. SwfFile:escape('<%=swfFilePath%>'),
  28. Scale:0.6,
  29. ZoomTransition:'easeOut',
  30. ZoomTime:0.5,
  31. ZoomInterval:0.2,
  32. FitPageOnLoad:true,
  33. FitWidthOnLoad:false,
  34. FullScreenAsMaxWindow:false,
  35. ProgressiveLoading:false,
  36. MinZoomSize:0.2,
  37. MaxZoomSize:5,
  38. SearchMatchAll:false,
  39. InitViewMode:'SinglePage',
  40. ViewModeToolsVisible:true,
  41. ZoomToolsVisible:true,
  42. NavToolsVisible:true,
  43. CursorToolsVisible:true,
  44. SearchToolsVisible:true,
  45. localeChain:'en_US'
  46. }});
  47. </script>
  48. </div>
  49. </body>
  50. </html>

7.启动tomcat,部署当前web应用
8.地址栏输入http://localhost:8080/ctcesims/documentUpload.jsp 如下图:

Java+FlexPaper+swfTools仿百度文库文档在线预览系统设计与实现_第4张图片

单击选择文件,选择您要上传的文档,笔者选择的是lunwen.doc文件,然后单击上传,处理完成后,打印如下信息,如下图所示:
Java+FlexPaper+swfTools仿百度文库文档在线预览系统设计与实现_第5张图片
单击预览按钮,就会生成预览界面,如下图:
Java+FlexPaper+swfTools仿百度文库文档在线预览系统设计与实现_第6张图片
9.若出现swf无法预览,请访问
http://www.macromedia.com/support/documentation/en/flashplayer/help/settings_manager04a.html#119065将生成swf的文件夹设置为信任文件位置。
由于时间仓促,以上只是简单示例,很多情况还需要进一步考虑!

参考资料:
http://blog.csdn.net/iamduoluo/article/details/6727031
http://www.cnblogs.com/star-studio/archive/2011/12/09/2282411.html#2497889

你可能感兴趣的:(FlexPaper)