目录
安装phpword包
通过composer安装phpword包。因为是使用thinkphp架构,安装挺方便的。
直接下载phpword压缩包有问题。
composer require phpoffice/phpword
准备一个word模板(docx格式)
准备好word模板后,只需要用变量替换需要替换的值,如下图所示,将房东名替换成${name}。
前端调用代码
系统前端是使用vue3+element Ui开发的。所以请求用到axios。其中设置responseType
。responseType
表示服务器响应的数据类型,可以是 ‘arraybuffer’, ‘blob’, ‘document’, ‘json’, ‘text’, ‘stream’。默认的 responseType: ‘json’,
而axios下载文件需要设置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')); //输出文件内容 echo fread($file_type, filesize($file_url)); fclose($file_type); }
one more thing
在传输过程中,可能会出现文件名是乱码的问题。也就是Content-Disposition中filename中文是乱码。解决方法如下:
php端使用json_encode(filename)
前端使用JSON.parse()