php zip pdf word rar类库
pdf2swf+flexpaper解决pdf在线阅读(类百度文库) PHP利用openoffice把office转成pdf格式,今天我们将为大家介绍PHP依靠com.sun.star.ServiceManager来转换Word为PDF文档的相关技巧<?php
set_time_limit(0);
function MakePropertyValue($name, $value, $osm)
{
$oStruct = $osm->Bridge_GetStruct("com.sun.star.beans.PropertyValue");
$oStruct->Name = $name;
$oStruct->Value = $value;
return $oStruct;
}
function word2pdf($doc_url, $output_url)
{
$osm = new COM("com.sun.star.ServiceManager") or die ("请确认OpenOffice.org库是否已经安装.\n");
$args = array(MakePropertyValue("Hidden", true, $osm));
$oDesktop = $osm->createInstance("com.sun.star.frame.Desktop");
$oWriterDoc = $oDesktop->loadComponentFromURL($doc_url, "_blank", 0, $args);
$export_args = array(MakePropertyValue("FilterName", "writer_pdf_Export", $osm));
$oWriterDoc->storeToURL($output_url, $export_args);
$oWriterDoc->close(true);
}
$output_dir = "D:/temp/";
$doc_file = "D:/temps/test.doc";
$pdf_file = "test.pdf";
$output_file = $output_dir . $pdf_file;
$doc_file = "file:///" . $doc_file;
$output_file = "file:///" . $output_file;
word2pdf($doc_file, $output_file);
?>
RarArchive类 解压rar
PclZip 向已有的zip添加用add
<?php
include_once('include/pclzip.lib.php');
$archive = new PclZip('archive.zip');//可以是绝对路径
//解压缩到extract/folder/这个目录中
$list = $archive->extract(PCLZIP_OPT_PATH, "extract/folder/");
//增加这个目录在压缩档中,完成以后压缩档里面会有backup这个目录,backup里面会有这两个档案
$list = $archive->create("file.txt,image.gif",PCLZIP_OPT_ADD_PATH, "backup");
//去掉部份的路径,这里完成后会变成test/file.txt
$list = $archive->add("/usr/local/user/test/file.txt",PCLZIP_OPT_REMOVE_PATH, "/usr/local/user");
//把所有路径都去掉,这个压缩档建立完后,里面就只会有file.txt跟image.gif,不会有目录了
$list = $archive->create("data/file.txt images/image.gif",PCLZIP_OPT_REMOVE_ALL_PATH);
//把解压缩出来的档案的CHMOD设成0777
$list = $archive->extract(PCLZIP_OPT_SET_CHMOD, 0777);
//解压缩部份的档案,这个参数是使用档案名称判别
//引数可以用下面这样的阵列
$rule_list = 'test/aaa.txt';
$rule_list = 'test/ddd.txt';
//或是下面这样,一个字串中,用逗号分隔每个要解压缩的档案
$rule_list = "test/aaa.txt,test/ddd.txt";
$list = $archive->extract(PCLZIP_OPT_BY_NAME,$rule_list);
//解压缩部份的档案,使用php的ereg()函式,档案名称有比对成功的都会被解压缩
$list = $archive->extract(PCLZIP_OPT_BY_EREG, "aa");
//解压缩部份的档案,使用php的preg_match()函式,档案名称有比对成功的都会被解压缩
$list = $archive->extract(PCLZIP_OPT_BY_PREG, "/^bb/");
//上面这两个函式如果不懂的话,请先研究正规表示法(Regular Expression)
//依照阵列中元素的索引解压缩,可是我不太懂index啥 = =a
$list = $archive->extract(PCLZIP_OPT_BY_INDEX, array('0-1','6-7'));
//将一个档案内容解压缩成一个字串
$list = $archive->extract(PCLZIP_OPT_BY_NAME, "data/readme.txt",PCLZIP_OPT_EXTRACT_AS_STRING);
//将一个档案内容解压缩完后直接输出(echo)
$list = $archive->extract(PCLZIP_OPT_BY_NAME, "data/readme.txt",PCLZIP_OPT_EXTRACT_IN_OUTPUT);
//将一个档案加入一个压缩档中,但不会对此档案压缩
$list = $archive->add("data/file.txt", PCLZIP_OPT_NO_COMPRESSION);
//对此压缩档增加一个注解,如果原本就有注解的话会被覆盖掉
$list = $archive->create("data", PCLZIP_OPT_COMMENT, "Add a comment");
//对此压缩档增加一个注解,如果原本就有注解的话会接在后面
$list = $archive->add("data", PCLZIP_OPT_ADD_COMMENT, "Add a comment after the existing one");
//对此压缩档增加一个注解,如果原本就有注解的话会放在原本的注解前面
$list = $archive->add("data", PCLZIP_OPT_PREPEND_COMMENT, "Add a comment before the existing one");
if ($list == 0) {
die("Error : ".$archive->errorInfo(true));
}
?>
phpdocx操作word的php类
下载地址:http://www.phpdocx.com/
在线演示地址:http://www.phpdocx.com/demo/sample-word-report
3,tcpdf操作pdf的php类
下载地址:http://sourceforge.net/projects/html2fpdf/?source=recommended
在线演示地址:http://www.tcpdf.org/examples.php
Html转pdf的工具——wkhtmltopdf
<?php shell_exec("wkhtmltopdf http://www.shwzzz.cn/ 1.pdf") ?>
wkhtmltopdf 有个很好的方法,就是在那个div的样式后添加一个:page-break-inside:avoid;就ok了
<style type="text/css">
*{ margin:0px; padding:0px;}
div{ width:800px; min-height:1362px;margin:auto;page-break-inside:avoid;}
</style>
<body>
<div style=" background:#030"></div>
<div style=" background:#033"></div>
afsds
页:
[1]