要給最常用出租屋管理系統(tǒng)增加個合同功能岖食,mark下知識點。要生成合同就需要使用phpword入篮。
安裝phpword包
通過composer安裝phpword包斩箫。因為是使用thinkphp架構(gòu),安裝挺方便的蝇恶。
直接下載phpword壓縮包有問題
composer require phpoffice/phpword
準備一個word模板(docx格式)
準備好word模板后拳魁,只需要用變量替換需要替換的值,如下圖所示撮弧,將房東名替換成${name}潘懊。
前端調(diào)用代碼
系統(tǒng)前端是使用vue3+element Ui開發(fā)的。所以請求用到axios贿衍。其中設(shè)置responseType
授舟。responseType
表示服務(wù)器響應(yīng)的數(shù)據(jù)類型,可以是 'arraybuffer', 'blob', 'document', 'json', 'text', 'stream'贸辈。默認的 responseType: 'json',
而axios下載文件需要設(shè)置responseType: 'blob',
axios.post(url, data, { headers: { 'X-CSRF-TOKEN': this.token }, responseType: 'blob' })
.then((res) => {
const { data, headers } = res
const contentDisposition = headers['content-disposition']
const patt = new RegExp('filename=([^;]+\.[^\.;]+);*')
const result = patt.exec(contentDisposition)
const filename = decodeURI(JSON.parse(result[1])) // 處理文件名,解決中文亂碼問題
const blob = new Blob([data], { type: headers['content-type'] })
let dom = document.createElement('a')
let url = window.URL.createObjectURL(blob)
dom.href = url
dom.download = decodeURI(filename)
dom.style.display = 'none'
document.body.appendChild(dom)
dom.click()
dom.parentNode.removeChild(dom)
window.URL.revokeObjectURL(url)
}).catch((err) => { })
PHP處理代碼
后端方面的代碼如下释树。Talk is cheap, show me the code.
public function contract()
{
$tmp=new \PhpOffice\PhpWord\TemplateProcessor('static/wordfile/contract.docx');//打開模板
$tmp->setValue('name', '君常笑');//替換變量name
$tmp->setValue('mobile', '12');//替換變量mobile
$tmp->saveAs('../tempfile/簡歷.docx');//另存為
$file_url = '../tempfile/簡歷.docx';
$file_name=basename($file_url);
$file_type=explode('.', $file_url);
$file_type=$file_type[count($file_type)-1];
$file_type=fopen($file_url, 'r'); //打開文件
//輸入文件標簽
header("Content-type: application/octet-stream");
header("Accept-Ranges: bytes");
header("Accept-Length: ".filesize($file_url));
header("Content-Disposition:attchment; filename=" . json_encode('合同.docx'));
//輸出文件內(nèi)容
echo fread($file_type, filesize($file_url));
fclose($file_type);
}
one more thing
在傳輸過程中,可能會出現(xiàn)文件名是亂碼的問題擎淤。也就是Content-Disposition中filename中文是亂碼奢啥。解決方法如下:
php端使用json_encode(filename)
前端使用JSON.parse()