使用 PHP 的 FPDF 中的特殊字符
我有一个用户可以填写的网络表单,该内容使用FPDF和PHP填充PDF。当用户输入带有撇号的单词时,PDF 上该单词的前面会出现一个斜杠。
同样,商标符号等特殊字符的编码错误。
FPDF常见问题解答说要使用:
$str = utf8_decode($str);
但我不确定如何将其应用于整个PDF。我试图把它想象成一个HTML页面,但这无济于事。
有什么想法吗?
我有一个用户可以填写的网络表单,该内容使用FPDF和PHP填充PDF。当用户输入带有撇号的单词时,PDF 上该单词的前面会出现一个斜杠。
同样,商标符号等特殊字符的编码错误。
FPDF常见问题解答说要使用:
$str = utf8_decode($str);
但我不确定如何将其应用于整个PDF。我试图把它想象成一个HTML页面,但这无济于事。
有什么想法吗?
通过执行以下操作(pagesubtitle是表单中文本字段的名称)来解决这个问题):
$reportSubtitle = stripslashes($_POST['pagesubtitle']);
$reportSubtitle = iconv('UTF-8', 'windows-1252', $reportSubtitle);
然后打印出来:
$pdf->Write (6, $reportSubtitle);
这将删除撇号后面任何不需要的斜杠,并使用“iconv”功能打印特殊字符,例如 ™
以上所有内容都不适合我,但我确实让它起作用了。
我设法通过把每个奇怪的字符翻译成它的url值来“野蛮人的方式”做到这一点。然后只需解码网址,瞧!
function em($word) {
$word = str_replace("@","%40",$word);
$word = str_replace("`","%60",$word);
$word = str_replace("¢","%A2",$word);
$word = str_replace("£","%A3",$word);
$word = str_replace("¥","%A5",$word);
$word = str_replace("|","%A6",$word);
$word = str_replace("«","%AB",$word);
$word = str_replace("¬","%AC",$word);
$word = str_replace("¯","%AD",$word);
$word = str_replace("º","%B0",$word);
$word = str_replace("±","%B1",$word);
$word = str_replace("ª","%B2",$word);
$word = str_replace("µ","%B5",$word);
$word = str_replace("»","%BB",$word);
$word = str_replace("¼","%BC",$word);
$word = str_replace("½","%BD",$word);
$word = str_replace("¿","%BF",$word);
$word = str_replace("À","%C0",$word);
$word = str_replace("Á","%C1",$word);
$word = str_replace("Â","%C2",$word);
$word = str_replace("Ã","%C3",$word);
$word = str_replace("Ä","%C4",$word);
$word = str_replace("Å","%C5",$word);
$word = str_replace("Æ","%C6",$word);
$word = str_replace("Ç","%C7",$word);
$word = str_replace("È","%C8",$word);
$word = str_replace("É","%C9",$word);
$word = str_replace("Ê","%CA",$word);
$word = str_replace("Ë","%CB",$word);
$word = str_replace("Ì","%CC",$word);
$word = str_replace("Í","%CD",$word);
$word = str_replace("Î","%CE",$word);
$word = str_replace("Ï","%CF",$word);
$word = str_replace("Ð","%D0",$word);
$word = str_replace("Ñ","%D1",$word);
$word = str_replace("Ò","%D2",$word);
$word = str_replace("Ó","%D3",$word);
$word = str_replace("Ô","%D4",$word);
$word = str_replace("Õ","%D5",$word);
$word = str_replace("Ö","%D6",$word);
$word = str_replace("Ø","%D8",$word);
$word = str_replace("Ù","%D9",$word);
$word = str_replace("Ú","%DA",$word);
$word = str_replace("Û","%DB",$word);
$word = str_replace("Ü","%DC",$word);
$word = str_replace("Ý","%DD",$word);
$word = str_replace("Þ","%DE",$word);
$word = str_replace("ß","%DF",$word);
$word = str_replace("à","%E0",$word);
$word = str_replace("á","%E1",$word);
$word = str_replace("â","%E2",$word);
$word = str_replace("ã","%E3",$word);
$word = str_replace("ä","%E4",$word);
$word = str_replace("å","%E5",$word);
$word = str_replace("æ","%E6",$word);
$word = str_replace("ç","%E7",$word);
$word = str_replace("è","%E8",$word);
$word = str_replace("é","%E9",$word);
$word = str_replace("ê","%EA",$word);
$word = str_replace("ë","%EB",$word);
$word = str_replace("ì","%EC",$word);
$word = str_replace("í","%ED",$word);
$word = str_replace("î","%EE",$word);
$word = str_replace("ï","%EF",$word);
$word = str_replace("ð","%F0",$word);
$word = str_replace("ñ","%F1",$word);
$word = str_replace("ò","%F2",$word);
$word = str_replace("ó","%F3",$word);
$word = str_replace("ô","%F4",$word);
$word = str_replace("õ","%F5",$word);
$word = str_replace("ö","%F6",$word);
$word = str_replace("÷","%F7",$word);
$word = str_replace("ø","%F8",$word);
$word = str_replace("ù","%F9",$word);
$word = str_replace("ú","%FA",$word);
$word = str_replace("û","%FB",$word);
$word = str_replace("ü","%FC",$word);
$word = str_replace("ý","%FD",$word);
$word = str_replace("þ","%FE",$word);
$word = str_replace("ÿ","%FF",$word);
return $word;
}
当然,我调用函数
$weirdword = "Días, Miércoles, Sábado,miércoles"; //Some spanish days
$weirdword = em($weirdword);
$weirdword = urldecode($weirdword);
echo $weirdword;
给出输出:
迪亚斯,米尔科莱斯,萨巴多,米尔科莱斯