司的某項(xiàng)業(yè)務(wù)需要與用戶(hù)線上簽訂協(xié)議,即用戶(hù)在線手寫(xiě)一個(gè)簽名,后臺(tái)將公司公章信息和用戶(hù)的簽名以及合同信息生成一份PDF文件,供用戶(hù)查看和下載。
比對(duì)了一些插件,我們最終決定使用dompdf這個(gè)插件,插件的github在這里:https://github.com/dompdf/dompdf。
1. 使用方法
// 引入命名空間 use Dompdf\Dompdf; // 初始化dompdf對(duì)象 $dompdf = new Dompdf(); // 加載html文檔內(nèi)容 $dompdf->loadHtml('hello world'); // 設(shè)置紙張類(lèi)型和方向 $dompdf->setPaper('A4', 'landscape'); // 渲染HTML為PDF $dompdf->render(); // 流輸出 $dompdf->stream();
2. 常見(jiàn)問(wèn)題和解決辦法
2.1 中文亂碼的問(wèn)題
插件對(duì)于字體和編碼問(wèn)題是這樣形容的:
PDF documents internally support the following fonts: Helvetica, Times-Roman, Courier, Zapf-Dingbats, & Symbol. These fonts only support Windows ANSI encoding. In order for a PDF to display characters that are not available in Windows ANSI, you must supply an external font. Dompdf will embed any referenced font in the PDF so long as it has been pre-loaded or is accessible to dompdf and reference in CSS @font-face rules. See the font overview for more information on how to use fonts.The DejaVu TrueType fonts have been pre-installed to give dompdf decent Unicode character coverage by default. To use the DejaVu fonts reference the font in your stylesheet, e.g. body { font-family: DejaVu Sans; } (for DejaVu Sans). The following DejaVu 2.34 fonts are available: DejaVu Sans, DejaVu Serif, and DejaVu Sans Mono.
嘗試了一下,默認(rèn)帶的字體是無(wú)法渲染中文的,使用CSS的@font-face引入會(huì)報(bào)錯(cuò)(也可能是我打開(kāi)方式不對(duì))。這樣就只好自己引入一個(gè)字體了。
插件給了一個(gè)安裝語(yǔ)言文件的工具,地址再這里:https://github.com/dompdf/utils。
使用步驟:
這樣,我們就可以在html文檔的css中使用font-family屬性來(lái)指定字體了。
html { font-family: simkai; }
2.2 圖片無(wú)法展示
插件應(yīng)該是無(wú)法直接顯示網(wǎng)絡(luò)圖片,所以需要將圖片轉(zhuǎn)換為BASE64格式才能顯示。
將HTML文檔中的所有圖片轉(zhuǎn)換為BASE64的方式:
function imgToBase64($html) { $html = preg_replace_callback('/<img(?:.*?)src="(.*?)"(?:.*?)\/?>/', function($matches) { $imageInfo = getimagesize($matches[1]); $base64 = "" . chunk_split(base64_encode(file_get_contents($matches[1]))); $base64_image = 'data:' . $imageInfo['mime'] . ';base64,' . $base64; return str_replace($matches[1], $base64_image, $matches[0]); }, $html); return $html; }
這樣轉(zhuǎn)換其實(shí)性能影響挺大的,感覺(jué)性能不太好可以加一下緩存。
當(dāng)今數(shù)字時(shí)代,網(wǎng)站是企業(yè)和個(gè)人的必需品。而HTML是創(chuàng)建網(wǎng)站的基礎(chǔ),它賦予了網(wǎng)站結(jié)構(gòu)、內(nèi)容和交互性。本文將深入探討HTML,提供一個(gè)全面的指南,幫助你掌握網(wǎng)站設(shè)計(jì)的關(guān)鍵。
什么是HTML?
HTML(超文本標(biāo)記語(yǔ)言)是一種標(biāo)記語(yǔ)言,用于描述網(wǎng)頁(yè)的結(jié)構(gòu)和內(nèi)容。它由一組元素和屬性組成,這些元素和屬性定義了文本、圖像、鏈接和其他網(wǎng)頁(yè)組件。
HTML元素
HTML元素是構(gòu)成網(wǎng)頁(yè)基本構(gòu)建塊的標(biāo)簽。每個(gè)元素都有一個(gè)開(kāi)始標(biāo)簽和一個(gè)結(jié)束標(biāo)簽,它們之間包含元素的內(nèi)容。最常見(jiàn)的元素包括:
HTML屬性
屬性用于修改元素的行為或外觀。每個(gè)元素可以具有多個(gè)屬性,這些屬性由名稱(chēng)和值對(duì)組成。例如,<img>元素可以具有src屬性來(lái)指定圖像文件的路徑。
HTML結(jié)構(gòu)
HTML文檔遵循一個(gè)特定的結(jié)構(gòu),包括:
HTML交互性
雖然HTML本質(zhì)上是靜態(tài)的,但它可以與其他技術(shù)結(jié)合使用,如JavaScript和CSS,以創(chuàng)建交互式網(wǎng)站。例如,JavaScript可以用于驗(yàn)證表單輸入或創(chuàng)建動(dòng)畫(huà)效果。
學(xué)習(xí)HTML
學(xué)習(xí)HTML相對(duì)容易,有許多在線資源和教程可供使用。以下是一些提示:
掌握HTML的好處
掌握HTML有很多好處,包括:
結(jié)論
HTML是網(wǎng)站設(shè)計(jì)的基石。通過(guò)理解其基本原理、元素和結(jié)構(gòu),你可以解鎖創(chuàng)建引人入勝且功能豐富的網(wǎng)頁(yè)的能力。無(wú)論你是想建立自己的網(wǎng)站還是提升你的職業(yè)生涯,掌握HTML都是必不可少的。
、簡(jiǎn)介
在PHP中,htmlentities()函數(shù)是一個(gè)常用的字符串處理函數(shù),用于將字符串中的特殊字符(如<>等)轉(zhuǎn)換為HTML實(shí)體,以防止跨站點(diǎn)腳本攻擊(XSS)。
二、語(yǔ)法
htmlentities(string $string, int $flags = ENT_COMPAT | ENT_HTML401, string|null $encoding = ini_get("default_charset"), bool $double_encode = true)
三、參數(shù)解釋
$string:必需,要處理的字符串,字符串類(lèi)型。
$flags:可選,指定轉(zhuǎn)換過(guò)程中的一些規(guī)則和選項(xiàng),整數(shù)類(lèi)型,默認(rèn)為ENT_COMPAT | ENT_HTML401。
$encoding:可選,指定要使用的字符編碼,字符串類(lèi)型,如果未指定,則使用ini_get("default_charset")函數(shù)獲取默認(rèn)字符編碼。
$double_encode:可選,指定是否對(duì)已存在的HTML實(shí)體進(jìn)行轉(zhuǎn)義,布爾類(lèi)型,默認(rèn)為true。
四、返回值
htmlentities()函數(shù)返回一個(gè)新的字符串,其中的特殊字符被轉(zhuǎn)換為了HTML實(shí)體。
五、使用實(shí)例
下面是一個(gè)簡(jiǎn)單的使用實(shí)例:
在上面的例子中,我們使用htmlentities()函數(shù)將字符串中的特殊字符(如<>等)轉(zhuǎn)換為了HTML實(shí)體,以防止跨站點(diǎn)腳本攻擊(XSS)。
六、注意事項(xiàng)
1、在使用htmlentities()函數(shù)時(shí),需要注意轉(zhuǎn)換規(guī)則。例如,它只會(huì)將特殊字符轉(zhuǎn)換為HTML實(shí)體,但不會(huì)對(duì)其他類(lèi)型的攻擊進(jìn)行防護(hù),例如SQL注入攻擊、跨站點(diǎn)請(qǐng)求偽造(CSRF)攻擊等。
2、在使用htmlentities()函數(shù)時(shí),需要注意字符編碼。例如,如果在使用htmlentities()函數(shù)時(shí)未指定字符編碼,可能會(huì)導(dǎo)致轉(zhuǎn)換結(jié)果不正確,從而引發(fā)安全性問(wèn)題。
3在處理用戶(hù)輸入的文本時(shí),我們需要注意安全性問(wèn)題。例如,可以使用addslashes()函數(shù)來(lái)防止SQL注入攻擊,在輸出到HTML頁(yè)面中時(shí),需要使用htmlentities()函數(shù)防止跨站點(diǎn)腳本攻擊(XSS)。
*請(qǐng)認(rèn)真填寫(xiě)需求信息,我們會(huì)在24小時(shí)內(nèi)與您取得聯(lián)系。