原文連接地址 http://www.javashuo.com/article/p-ufcfiuaw-ed.htmlphp
OpenOffice
OpenOffice 是一套開源跨平臺的辦公軟件,由許多自由軟件人士共同來維持,讓你們能在 Microsoft Office 以外,還能有免費的 Office 能夠使用。html
OpenOffice 與微軟的辦公軟件套件兼容,能將 doc、xls、ppt 等文件轉換爲 PDF 格式,其功能絕對不比 Microsoft Office 差。java
OpenOffice 官網:http://www.openoffice.org/ajax
OpenOffice 下載:http://www.openoffice.org/download/index.html安全
OpenOffice 須要 java 支持,請確認安裝了 JDK,並配置了 JRE 環境變量。服務器
1. 配置組件服務
OpenOffice 安裝完成以後,按 win+R 快捷鍵進入運行菜單,輸入 Dcomcnfg 打開組件服務。less
[組件服務] >> [計算機] >> [個人電腦] >> [DCOM配置] >> [OpenOffice Service Manager]socket
右鍵打開屬性面板,選擇安全選項卡,分別在 啓動和激活權限 和 訪問權限 上勾選自定義,添加 Everyone 的權限。ide
↑ 啓動和激活權限 和 訪問權限 都使用自定義配置工具
↑ 添加 Everyone 用戶組,記得確認前先檢查名稱
↑ 兩個自定義配置相同,容許 Everyone 擁有全部權限
再選擇標識選項卡,勾選 交互式用戶,保存設置後退出。
2. 後臺運行軟件
安裝完 OpenOffice 後,須要啓動一次確認軟件能夠正常運行,而後再打開命令行運行如下命令:
切換到安裝目錄: cd C:\Program Files\OpenOffice 4\program
後臺運行該軟件: soffice -headless-accept="socket,host=127.0.0.1,port=8100;urp;" -nofirststartwizard
PS:該命令只須要執行一次,就能夠使軟件一直在後臺運行,即便重啓服務器也不受影響。
3. 配置PHP擴展
若是是 PHP5.4 之前的版本,須要在 php.ini 裏把 com.allow_dcom = true 打開(即去掉前面的分號)。
若是是 PHP5.4 以後的版本,則要在 php.ini 裏增長一行擴展 extension = php_com_dotnet.dll 。
重啓 Apache 或 IIS 服務器,打印 phpinfo() 信息,檢查 com_dotnet 擴展是開啓。
↑ 檢查 php 的 ext 目錄中 是否存在 com_dotnet.dll 文件,若是沒有請自行下載對應版本的 dll
4. 實現文件轉換
PDF 轉換工具(支持 doc, docx, xls, xlsx, ppt, pptx 等格式)
class PDFConverter { private $com; /** * need to install openoffice and run in the background * soffice -headless-accept="socket,host=127.0.0.1,port=8100;urp;" -nofirststartwizard */ public function __construct() { try { $this->com = new COM('com.sun.star.ServiceManager'); } catch (Exception $e) { die('Please be sure that OpenOffice.org is installed.'); } } /** * Execute PDF file(absolute path) conversion * @param $source [source file] * @param $export [export file] */ public function execute($source, $export) { $source = 'file:///' . str_replace('\\', '/', $source); $export = 'file:///' . str_replace('\\', '/', $export); $this->convertProcess($source, $export); } /** * Get the PDF pages * @param $pdf_path [absolute path] * @return int */ public function getPages($pdf_path) { if (!file_exists($pdf_path)) return 0; if (!is_readable($pdf_path)) return 0; if ($fp = fopen($pdf_path, 'r')) { $page = 0; while (!feof($fp)) { $line = fgets($fp, 255); if (preg_match('/\/Count [0-9]+/', $line, $matches)) { preg_match('/[0-9]+/', $matches[0], $matches2); $page = ($page < $matches2[0]) ? $matches2[0] : $page; } } fclose($fp); return $page; } return 0; } private function setProperty($name, $value) { $struct = $this->com->Bridge_GetStruct('com.sun.star.beans.PropertyValue'); $struct->Name = $name; $struct->Value = $value; return $struct; } private function convertProcess($source, $export) { $desktop_args = array($this->setProperty('Hidden', true)); $desktop = $this->com->createInstance('com.sun.star.frame.Desktop'); $export_args = array($this->setProperty('FilterName', 'writer_pdf_Export')); $program = $desktop->loadComponentFromURL($source, '_blank', 0, $desktop_args); $program->storeToURL($export, $export_args); $program->close(true); } }
使用 PDFConverter(必須傳入絕對路徑)
$arr = array('doc', 'docx', 'xls', 'xlsx', 'ppt', 'pptx'); $converter = new PDFConverter(); foreach ($arr as $ext) { $source = __DIR__ . '/office/test.' . $ext; $export = __DIR__ . '/pdf/test.' . $ext . '.pdf'; $converter->execute($source, $export); echo '<p>' . $ext . ' Done</p>'; }
Thinkphp中使用
建立: 把第四步的 PDFConverter 類放進來
使用:
public function uploadFile () { $storeID = I('storeID'); $printID = I('printID'); $upload = new \Think\Upload();// 實例化上傳類 $upload->maxSize = 0;// 設置附件上傳大小 $upload->exts = array ('doc','docx','xls','xlsx','ppt','pptx','jpg','gif','png','jpeg'); $upload->savePath = '/office/'; // 設置附件上傳目錄 // 上傳文件 $info = $upload->uploadOne($_FILES['file']); if (!$info) {// 上傳錯誤提示錯誤信息 $ajax['code'] = 'error'; $ajax['msg'] = $upload->getError(); } else {// 上傳成功 $file = $info['savepath'] . $info['savename']; Vendor('officeToPDF.officetopdf'); $converter = new \PDFConverter(); $source = dirname(dirname(dirname(__DIR__))) . '/Uploads' . $file; $export = dirname(dirname(dirname(__DIR__))) . '/Uploads/pdf/'.date('Y-m-d', time()).'/'.$info['savename']. '.pdf'; $converter->execute($source, $export); } $this->ajaxReturn($file); }