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仿百度文库文档在线预览系统设计与实现
进入windows任务管理器查看有个进程soffice.bin,说明openoffice启动成功!
Java+FlexPaper+swfTools仿百度文库文档在线预览系统设计与实现
(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)创建documentUpload.jsp文件

packagecom.cectsims.util;
importjava.io.BufferedInputStream;
importjava.io.File;
importjava.io.IOException;
importjava.io.InputStream;


importcom.artofsolving.jodconverter.DocumentConverter;
importcom.artofsolving.jodconverter.openoffice.connection.OpenOfficeConnection;
importcom.artofsolving.jodconverter.openoffice.connection.SocketOpenOfficeConnection;
importcom.artofsolving.jodconverter.openoffice.converter.OpenOfficeDocumentConverter;


/**
*docdocx格式转换
*/
publicclassDocConverter{
privatestaticfinalintenvironment=1;//环境1:windows2:linux
privateStringfileString;//(只涉及pdf2swf路径问题)
privateStringoutputPath="";//输入路径,如果不设置就输出在默认的位置
privateStringfileName;
privateFilepdfFile;
privateFileswfFile;
privateFiledocFile;


publicDocConverter(StringfileString){
ini(fileString);
}


/**
*重新设置file
*
*@paramfileString
*/
publicvoidsetFile(StringfileString){
ini(fileString);
}


/**
*初始化
*
*@paramfileString
*/
privatevoidini(StringfileString){
this.fileString=fileString;
fileName=fileString.substring(0,fileString.lastIndexOf("."));
docFile=newFile(fileString);
pdfFile=newFile(fileName+".pdf");
swfFile=newFile(fileName+".swf");
}


/**
*转为PDF
*
*@paramfile
*/
privatevoiddoc2pdf()throwsException{
if(docFile.exists()){
if(!pdfFile.exists()){
OpenOfficeConnectionconnection=newSocketOpenOfficeConnection(8100);
try{
connection.connect();
DocumentConverterconverter=newOpenOfficeDocumentConverter(connection);
converter.convert(docFile,pdfFile);
//closetheconnection
connection.disconnect();
System.out.println("****pdf转换成功,PDF输出:"+pdfFile.getPath()+"****");
}catch(java.net.ConnectExceptione){
e.printStackTrace();
System.out.println("****swf转换器异常,openoffice服务未启动!****");
throwe;
}catch(com.artofsolving.jodconverter.openoffice.connection.OpenOfficeExceptione){
e.printStackTrace();
System.out.println("****swf转换器异常,读取转换文件失败****");
throwe;
}catch(Exceptione){
e.printStackTrace();
throwe;
}
}else{
System.out.println("****已经转换为pdf,不需要再进行转化****");
}
}else{
System.out.println("****swf转换器异常,需要转换的文档不存在,无法转换****");
}
}


/**
*转换成swf
*/
@SuppressWarnings("unused")
privatevoidpdf2swf()throwsException{
Runtimer=Runtime.getRuntime();
if(!swfFile.exists()){
if(pdfFile.exists()){
if(environment==1){//windows环境处理
try{
Processp=r.exec("D:/ProgramFiles/SWFTools/pdf2swf.exe"+pdfFile.getPath()+"-o"+swfFile.getPath()+"-T9");
System.out.print(loadStream(p.getInputStream()));
System.err.print(loadStream(p.getErrorStream()));
System.out.print(loadStream(p.getInputStream()));
System.err.println("****swf转换成功,文件输出:"
+swfFile.getPath()+"****");
if(pdfFile.exists()){
pdfFile.delete();
}


}catch(IOExceptione){
e.printStackTrace();
throwe;
}
}elseif(environment==2){//linux环境处理
try{
Processp=r.exec("pdf2swf"+pdfFile.getPath()
+"-o"+swfFile.getPath()+"-T9");
System.out.print(loadStream(p.getInputStream()));
System.err.print(loadStream(p.getErrorStream()));
System.err.println("****swf转换成功,文件输出:"
+swfFile.getPath()+"****");
if(pdfFile.exists()){
pdfFile.delete();
}
}catch(Exceptione){
e.printStackTrace();
throwe;
}
}
}else{
System.out.println("****pdf不存在,无法转换****");
}
}else{
System.out.println("****swf已经存在不需要转换****");
}
}


staticStringloadStream(InputStreamin)throwsIOException{


intptr=0;
in=newBufferedInputStream(in);
StringBufferbuffer=newStringBuffer();


while((ptr=in.read())!=-1){
buffer.append((char)ptr);
}


returnbuffer.toString();
}
/**
*转换主方法
*/
@SuppressWarnings("unused")
publicbooleanconver(){


if(swfFile.exists()){
System.out.println("****swf转换器开始工作,该文件已经转换为swf****");
returntrue;
}


if(environment==1){
System.out.println("****swf转换器开始工作,当前设置运行环境windows****");
}else{
System.out.println("****swf转换器开始工作,当前设置运行环境linux****");
}
try{
doc2pdf();
pdf2swf();
}catch(Exceptione){
e.printStackTrace();
returnfalse;
}


if(swfFile.exists()){
returntrue;
}else{
returnfalse;
}
}


/**
*返回文件路径
*
*@params
*/
publicStringgetswfPath(){
if(swfFile.exists()){
StringtempString=swfFile.getPath();
tempString=tempString.replaceAll("\\\\","/");
returntempString;
}else{
return"";
}


}
/**
*设置输出路径
*/
publicvoidsetOutputPath(StringoutputPath){
this.outputPath=outputPath;
if(!outputPath.equals("")){
StringrealName=fileName.substring(fileName.lastIndexOf("/"),
fileName.lastIndexOf("."));
if(outputPath.charAt(outputPath.length())=='/'){
swfFile=newFile(outputPath+realName+".swf");
}else{
swfFile=newFile(outputPath+realName+".swf");
}
}
}


}

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

  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

  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仿百度文库文档在线预览系统设计与实现

单击选择文件,选择您要上传的文档,笔者选择的是lunwen.doc文件,然后单击上传,处理完成后,打印如下信息,如下图所示:
Java+FlexPaper+swfTools仿百度文库文档在线预览系统设计与实现
单击预览按钮,就会生成预览界面,如下图:
Java+FlexPaper+swfTools仿百度文库文档在线预览系统设计与实现
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

相关推荐