標籤:net src com 也會 絕對路徑 location ext encode chm
php匯出為word原理
一般,有2種方法可以匯出doc文檔,一種是使用com,並且作為php的一個擴充庫安裝到伺服器上,然後建立一個com,調用它的方法。安裝過office的伺服器可以調用一個叫word.application的com,可以產生word文檔,不過這種方式我不推薦,因為執行效率比較低(我測試了一下,在執行代碼的時候,伺服器會真的去開啟一個word用戶端)。理想的com應該是沒有介面的,在後台進行資料轉換,這樣效果會比較好,但是這些擴充一般需要收費。
第2種方法,就是用PHP匯出Word文檔內容直接寫入一個尾碼為doc的檔案中即可。使用這種方法不需要依賴第三方擴充,而且執行效率較高。
word本身的功能還是很強大的,它可以開啟html格式的檔案,並且能夠保留格式,即使尾碼為doc,它也能識別正常開啟。這就為我們提供了方便。但是有一個問題,html格式的檔案中的圖片只有一個地址,真正的圖片是儲存在其他地方的,也就是說,如果將HTML格式寫入doc中,那麼doc中將不能包含圖片。那我們如何建立包含圖片的doc文檔呢?我們可以使用和html很接近的mht格式。
mht格式和html很類似,只不過在mht格式中,外部連結進來的檔案,比片、Javascript、CSS會被base64進行編碼儲存。因此,單個mht檔案就可以儲存一個網頁中的所有資源,當然,相比html,它的尺寸也會比較大。
mht格式能被word識別嗎?我將一個網頁儲存成mht,然後修改尾碼名為doc,再用word開啟,OK,word也可以識別mht檔案,並且可以顯示圖片。
好了,既然doc可以識別mht,下面就是考慮如何將圖片放入mht了。由於html代碼中的圖片的地址都是寫在img標籤的src屬性中,因此,只要提取html代碼中的src屬性值,就可以獲得圖片地址。當然,有可能您擷取到的是相對路徑,沒關係,加上URL的首碼,改成絕對路徑就可以了。有了圖片地址,我們就可以通過file_get_content函數擷取到圖片檔案的具體內容,然後調用base64_encode函數將檔案內容編碼成base64編碼,最後插入到mht檔案的合適位置即可。
最後,我們有兩種PHP匯出Word文檔方法將檔案發送給用戶端,一種是先在伺服器端產生一個doc文檔,然後將這個doc文檔的地址記錄下來,最後,通過header("location:xx.doc");就可以讓用戶端下載這個doc。還有一種是直接發送html請求,修改HTML協議的header部分,將它的content-type設定為application/doc,將content-disposition設定為attachment,後面跟上檔案名稱,發送完html協議以後,直接將檔案內容發送給用戶端,也可以讓用戶端下載到這個doc文檔。
<?
Header("Content-type: application/octet-stream");
Header("Accept-Ranges: bytes");
Header("Content-type:application/vnd.ms-excel");
Header("Content-Disposition:attachment;filename=export_excel_gshjsl.xls");
$tx=‘表頭‘;
echo $tx."\n\n";
echo "編號"."\t";
echo "姓名"."\t";
echo "\n";
echo "=\"411481198507150666\""."\t";
echo "=\"0123456\""."\t"; //帶上引號方便字串輸出。相當如設定儲存格格式為文本。
echo "\n";
?>
順便把簡單匯出word文檔的代碼貼到這裡:
<?php
header("Content-Type: application/msword");
header("Content-Disposition: attachment; filename=doc.doc");
header("Pragma: no-cache");
header("Expires: 0");
$output = ‘<table border="1" cellspacing="2" cellpadding="2" width="90%" align="center">‘;
$output .= ‘<tr bgcolor="#cccccc"><td align="center">圖片</td></tr>‘;
$output .= ‘<tr bgcolor="#f6f7fa"><td><span style="color:#FF0000;"><strong>下面是一張圖片</strong></span></td></tr>‘;
$output .= ‘<tr><td align="center"><img src="http://zi.csdn.net/48260_2.gif"></td></tr>‘;
$output .= ‘</table>‘;
echo $output;
?>
PHP匯出excel word的代碼