原博客 http://blog.csdn.net/zfw198787/article/details/48781357
最详细的文件在线预览(openoffice+swftools+flexpaper)
1.1 本人使用的都是最新的软件包,版本见下图:
1.2 已经支持加载中文文件名
1.3 代码下载
1.概述
主要原理
1.通过第三方工具openoffice,将word、excel、ppt、txt等文件转换为pdf文件
2.通过swfTools将pdf文件转换成swf格式的文件
3.通过FlexPaper文档组件在页面上进行展示
2.安装包下载
1.openoffice是Apache下的一个开放免费的文字处理软件
下载版本:4.1.0
下载地址:http://www.openoffice.org/zh-cn/download/
2.SWFTools是一组用来处理Flash的swf文件的工具包,我们使用它将pdf文件转成swf文件!
下载版本:swftools-2013-04-09-1007
下载地址:http://www.swftools.org/download.html
3.FlexPaper是一个开源轻量级的在浏览器上显示各种文档的组件
下载地址:FlexPaper官网下载
4.JODConverter一个Java的OpenDocument文件转换器,在此我们只用到它的jar包
下载地址:JODCConverter下载
3.安装文件
1.将所下载的文件(JODConverter除外)进行安装,盘符可随自己设定!需要注意的是在openoffice安装完成后,当我们使用它时,需将它的服务打开。在次我们需要以命令的方式打开:
打开dos窗口,进入openoffice安装盘符,输入以下代码来启动服务:
soffice-headless -accept="socket,host=127.0.0.1,port=8100;urp;"-nofirststartwizard
注意最后一个命令前边的‘—’,可不要写错!服务起不来,项目可是继续不下去的哦.
官网启动服务截图如下:
本地截图:
3.开发过程
1.新建项目,将flexpaper文件中的js文件夹(包含了flexpaper_handlers.js,flexpaper.js, jquery.extensions.min.js,jquery.min.js, three.min.js这五个js文件主要是预览swf文件的插件)拷贝至网站根目录下的js文件夹;把locale文件夹拷贝到根目录下,把css文件夹拷贝到根目录下,将FlexPaperViewer.swf拷贝至网站根目录下(该文件主要是用在网页中播放swf文件的播放器),目录结构如下图:
注:jar包去下载的文件的lib目录下找. DocConverter类方法 pdf2swf()中pdf2swf命令的路径要根据实际值配置。
2.创建fileUpload.jsp
<%@ pagelanguage="java" contentType="text/html;charset=UTF-8" pageEncoding="UTF-8"%>
<!DOCTYPE html PUBLIC "-//W3C//DTDHTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type"content="text/html; charset=UTF-8">
<title>文档在线预览系统</title>
<style>
body {margin-top:100px;background:#fff;font-family: Verdana, Tahoma;}
a {color:#CE4614;}
#msg-box {color: #CE4614; font-size:0.9em;text-align:center;}
#msg-box .logo {border-bottom:5px solid #ECE5D9;margin-bottom:20px;padding-bottom:10px;}
#msg-box .title {font-size:1.4em;font-weight:bold;margin:0 0 30px 0;}
#msg-box .nav {margin-top:20px;}
</style>
</head>
<body>
<div id="msg-box">
<form name="form1" method="post"enctype="multipart/form-data"action="docUploadConvertAction.jsp">
<div class="title">
请上传要处理的文件,过程可能需要几分钟,请稍候片刻。
</div>
<p>
<input name="file1"type="file">
</p>
<p>
<input type="submit"name="Submit" value="上传">
</p>
</form >
</div>
</body>
</html>
3.创建转换页docUploadConvertAction.jsp
<%@ page language="java" contentType="text/html;charset=UTF-8" pageEncoding="UTF-8"%>
<%@page import="java.io.*"%>
<%@page import="java.util.Enumeration"%>
<%@page import="com.oreilly.servlet.MultipartRequest"%>
<%@page import="com.oreilly.servlet.multipart.DefaultFileRenamePolicy"%>
<%@page import="com.cectsims.util.DocConverter"%>
<%
//文件上传采用cos组件上传,可更换为commons-fileupload上传,文件上传后,保存在upload文件夹
//获取文件上传路径
String saveDirectory=application.getRealPath("/")+"upload";
//String saveDirectory="D:\\upload";
//打印上传路径信息
System.out.println(saveDirectory);
//每个文件最大50m
int maxPostSize = 50 * 1024 * 1024;
//采用cos缺省的命名策略,重名后加1,2,3...如果不加dfp重名将覆盖
DefaultFileRenamePolicy dfp = new DefaultFileRenamePolicy();
//response的编码为"UTF-8",同时采用缺省的文件名冲突解决策略,实现上传,如果不加dfp重名将覆盖
MultipartRequest multi = new MultipartRequest(request,saveDirectory, maxPostSize,"UTF-8",dfp);
//MultipartRequest multi = newMultipartRequest(request, saveDirectory, maxPostSize,"UTF-8");
//输出反馈信息
Enumeration files =multi.getFileNames();
while (files.hasMoreElements()) {
String name =(String)files.nextElement();
File f =multi.getFile(name);
if(f!=null){
String fileName =multi.getFilesystemName(name);
//获取上传文件的扩展名
StringextName=fileName.substring(fileName.lastIndexOf(".")+1);
//文件全路径
String lastFileName=saveDirectory+"\\" + fileName;
//获取需要转换的文件名,将路径名中的'\'替换为'/'
String converfilename =saveDirectory.replaceAll("\\\\", "/")+"/"+fileName;
System.out.println(converfilename);
//调用转换类DocConverter,并将需要转换的文件传递给该类的构造方法
DocConverter d = new DocConverter(converfilename);
//调用conver方法开始转换,先执行doc2pdf()将office文件转换为pdf;再执行pdf2swf()将pdf转换为swf;
d.conver();
//调用getswfPath()方法,打印转换后的swf文件路径
System.out.println(d.getswfPath());
//生成swf相对路径,以便传递给flexpaper播放器
String swfpath = "upload"+d.getswfPath().substring(d.getswfPath().lastIndexOf("/"));
System.out.println(swfpath);
//将相对路径放入sessio中保存
session.setAttribute("swfpath", swfpath);
out.println("上传的文件:"+lastFileName);
out.println("文件类型"+extName);
out.println("<hr>");
}
}
%>
<!DOCTYPE html PUBLIC "-//W3C//DTDHTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type"content="text/html; charset=UTF-8">
<title>Insert title here</title>
<style>
body {margin-top:100px;background:#fff;font-family: Verdana, Tahoma;}
a {color:#CE4614;}
#msg-box {color: #CE4614; font-size:0.9em;text-align:center;}
#msg-box .logo {border-bottom:5px solid #ECE5D9;margin-bottom:20px;padding-bottom:10px;}
#msg-box .title {font-size:1.4em;font-weight:bold;margin:0 0 30px 0;}
#msg-box .nav {margin-top:20px;}
</style>
</head>
<body>
<div>
<form name="viewForm"id="form_swf" action="documentView.jsp"method="POST">
<input type='submit' value='预览' class='BUTTON SUBMIT'/>
</form>
</div>
</body>
</html>
4.创建查看页documentView.jsp
<%@ page language="java" contentType="text/html;charset=UTF-8" pageEncoding="UTF-8"%>
<!doctype html>
<html>
<head>
<title>FlexPaper AdaptiveUI</title>
<meta http-equiv="Content-Type"content="text/html; charset=utf-8" />
<meta content="IE=Edge"http-equiv="X-UA-Compatible"></meta>
<meta name="viewport"content="initial-scale=1,user-scalable=no,maximum-scale=1,width=device-width"/>
<style type="text/css"media="screen">
html,body{height:100%; }
body { margin:0; padding:0; overflow:auto; }
#flashContent { display:none; }
</style>
<link rel="stylesheet"type="text/css" href="css/flexpaper.css"/>
<script type="text/javascript"src="js/jquery.min.js"></script>
<script type="text/javascript"src="js/jquery.extensions.min.js"></script>
<!--[if gte IE 10 | !IE]><!-->
<script type="text/javascript"src="js/three.min.js"></script>
<!--<![endif]-->
<script type="text/javascript"src="js/flexpaper.js"></script>
<script type="text/javascript"src="js/flexpaper_handlers.js"></script>
</head>
<body>
<%
String swfpath =(String)session.getAttribute("swfpath");
%>
<div id="documentViewer"class="flexpaper_viewer" style="position:absolute;left:10px;top:10px;"></div>
<script type="text/javascript">
var startDocument = "Paper";
$('#documentViewer').FlexPaperViewer(
{ config : {
//传入的swfpath路径必须是相对路径,如果是绝对路径,可以建立虚拟目录,在TOMCAT中建虚拟目录,要在server.xml的host中添加context,如:
//<host><ContextcrossContext="true" docBase="C:/Users/dimeng/fileStore"path="/fileStore" reloadable="false"/></host>
//C:/Users/dimeng/fileStore是我文件的根目录 /fileStore访问文件的虚拟路径
//如:通过/fileStore/10/2015/9/22/11.pdf访问C:/Users/dimeng/fileStore/10/2015/9/22/11.pdf
SWFFile :escape('<%=swfpath%>'),
Scale : 0.6,
ZoomTransition : 'easeOut',
ZoomTime : 0.5,
ZoomInterval : 0.1,
FitPageOnLoad : true,
FitWidthOnLoad : false,
FullScreenAsMaxWindow : false,
ProgressiveLoading :false,
MinZoomSize : 0.2,
MaxZoomSize : 5,
SearchMatchAll : false,
InitViewMode : 'TwoPage',//默认双页
//InitViewMode : 'Portrait',//单页
RenderingOrder : 'flash,html',
StartAtPage : '',
EnableWebGL : true,
ViewModeToolsVisible: true,
ZoomToolsVisible : true,
NavToolsVisible : true,
CursorToolsVisible :true,
SearchToolsVisible :true,
WMode : 'transparent',
localeChain: 'zh_CN'
}}
);
</script>
</body>
</html>
5.创建转换类DocConverter.java
package com.cectsims.util;
import java.io.BufferedInputStream;
import java.io.File;
import java.io.IOException;
import java.io.InputStream;
import com.artofsolving.jodconverter.DocumentConverter;
import com.artofsolving.jodconverter.openoffice.connection.OpenOfficeConnection;
importcom.artofsolving.jodconverter.openoffice.connection.OpenOfficeException;
importcom.artofsolving.jodconverter.openoffice.connection.SocketOpenOfficeConnection;
import com.artofsolving.jodconverter.openoffice.converter.OpenOfficeDocumentConverter;
/**
* doc docx格式转换
*/
publicclass DocConverter {
privatestaticfinalintenvironment = 1;// 环境 1:windows 2:linux
private String fileString;// (只涉及pdf2swf路径问题)
private String outputPath = "";// 输入路径,如果不设置就输出在默认的位置
private String fileName;
private File pdfFile;
private File swfFile;
private File docFile;
public DocConverter(String fileString) {
ini(fileString);
}
/**
* 重新设置file
*
* @param fileString
*/
publicvoid setFile(String fileString) {
ini(fileString);
}
/**
* 初始化
*
* @param fileString
*/
privatevoid ini(String fileString) {
this.fileString = fileString;
fileName = fileString.substring(0, fileString.lastIndexOf("."));
docFile = new File(fileString);
pdfFile = new File(fileName + ".pdf");
swfFile = new File(fileName + ".swf");
}
/**
* 转为PDF
*
* @param file
*/
privatevoid doc2pdf() throws Exception {
if (docFile.exists()) {
if (!pdfFile.exists()) {
OpenOfficeConnectionconnection = newSocketOpenOfficeConnection(8100);
try {
connection.connect();
DocumentConverter converter = new OpenOfficeDocumentConverter(connection);
converter.convert(docFile, pdfFile);
// close the connection
connection.disconnect();
System.out.println("****pdf转换成功,PDF输出:" + pdfFile.getPath()+ "****");
} catch (java.net.ConnectException e) {
e.printStackTrace();
System.out.println("****swf转换器异常,openoffice服务未启动!****");
throwe;
} catch (OpenOfficeException e) {
e.printStackTrace();
System.out.println("****swf转换器异常,读取转换文件失败****");
throwe;
} catch (Exception e) {
e.printStackTrace();
throwe;
}
} else {
System.out.println("****已经转换为pdf,不需要再进行转化****");
}
} else {
System.out.println("****swf转换器异常,需要转换的文档不存在,无法转换****");
}
}
/**
* 转换成 swf
*/
@SuppressWarnings("unused")
privatevoid pdf2swf() throws Exception {
Runtime r = Runtime.getRuntime();
if (!swfFile.exists()) {
if (pdfFile.exists()) {
if (environment == 1) {// windows环境处理
try {
Process p = r.exec("D:/install/swftool/pdf2swf.exe"+ pdfFile.getPath() + " -o "+ swfFile.getPath() + " -f -T 9 ");
//Process p =r.exec("D:\\install\\swftool\\pdf2swf.exe "+"D:\\upload\\33.pdf" + " -o "+ "D:\\upload\\33.swf"+ " -f -T 9 ");
loadStream(p.getInputStream());
//System.err.print(loadStream(p.getErrorStream()));
System.out.println("****swf转换成功,文件输出:"
+ swfFile.getPath() + "****");
/* if (pdfFile.exists()){
pdfFile.delete();
} */
} catch (IOException e) {
e.printStackTrace();
throwe;
}
} elseif (environment == 2) {// linux环境处理
try {
Process p = r.exec("pdf2swf " + pdfFile.getPath()
+ " -o " + swfFile.getPath() + " -f -T 9 ");
loadStream(p.getInputStream());
//System.err.print(loadStream(p.getErrorStream()));
System.out.println("****swf转换成功,文件输出:"
+ swfFile.getPath() + "****");
/* if(pdfFile.exists()) {
pdfFile.delete();
} */
} catch (Exception e) {
e.printStackTrace();
throwe;
}
}
} else {
System.out.println("****pdf不存在,无法转换****");
}
} else {
System.out.println("****swf已经存在不需要转换****");
}
}
static String loadStream(InputStream in) throws IOException {
intptr = 0;
in = new BufferedInputStream(in);
StringBuffer buffer = new StringBuffer();
while ((ptr = in.read()) != -1) {
buffer.append((char) ptr);
}
returnbuffer.toString();
}
/**
* 转换主方法
*/
@SuppressWarnings("unused")
publicboolean conver() {
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 (Exception e) {
e.printStackTrace();
returnfalse;
}
if (swfFile.exists()) {
returntrue;
} else {
returnfalse;
}
}
/**
* 返回文件路径
*
* @param s
*/
public String getswfPath() {
if (swfFile.exists()) {
String tempString = swfFile.getPath();
tempString = tempString.replaceAll("\\\\", "/");
returntempString;
} else {
return"";
}
}
/**
* 设置输出路径
*/
publicvoid setOutputPath(String outputPath) {
this.outputPath = outputPath;
if (!outputPath.equals("")) {
String realName = fileName.substring(fileName.lastIndexOf("/"),
fileName.lastIndexOf("."));
if (outputPath.charAt(outputPath.length()) == '/') {
swfFile = new File(outputPath + realName + ".swf");
} else {
swfFile = new File(outputPath + realName + ".swf");
}
}
}
publicstaticvoid main(String[] args) {
DocConverterd = new DocConverter("D:\\upload\\33.pdf");
try {
d.pdf2swf();
} catch (Exception e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
}
6.部署发布
启动tomcat,部署当前web应用
地址栏输入http://localhost:8080/ctcesims/documentUpload.jsp如下图:
单击选择文件,选择您要上传的文档,然后单击上传,处理完成后,打印如下信息,如下图所示:
单击预览按钮,就会生成预览界面,如下图:
4.常见问题
若出现swf无法预览,请访问
http://www.macromedia.com/support/documentation/en/flashplayer/help/settings_manager04a.html#119065
将生成swf的文件夹设置为信任文件位置。
1.4 若文件目录与项目目录不在一起,可将附件目录在服务器中设置为虚拟目录
在TOMCAT中建虚拟目录,要在server.xml的host中添加context,如:
<host><Context crossContext="true"docBase="C:/Users/dimeng/fileStore" path="/fileStore"reloadable="false"/></host>
C:/Users/dimeng/fileStore是我文件的根目录 /fileStore访问文件的虚拟路径
如:通过/fileStore/10/2015/9/22/11.pdf访问C:/Users/dimeng/fileStore/10/2015/9/22/11.pdf
1.5 最后,若需要去除打印功能及logo,可重新编译flexpaper 的 flash文件,网上也有下载