作者Clessin (Clemond)
看板PHP
标题Re: [请益] PHP 产生 RTF
时间Mon Jun 4 12:41:37 2012
※ 引述《chaoms (小企鹅)》之铭言:
: 观念你先厘清一下!因为看你叙述後~问题点应该不在编码~而是在程式
: rtf档头有定义codepage,由你叙述应该确定就是cpg950
: 那麽内容编码就是要符合cp950的编码规范,如果有unicode就须用\uXXXXX?格式
: 这个观念和HTML使用charset设big-5时显示unicode就需用&#XXXXX;格式一样
: 再来header的charset也可能会影响读取软体判别语系...
: 像你用cp950...header的charset应该用big-5才对..
: 另外你有写output buffering 你知道这个意义在哪里吗?
: 意思就是你程式有bom的话再输出这个rtf档案格式根本就错了..
: 目前你提供的资讯大概只能猜常发生状况就这些...
: 至於你写的程式是否有真的符合我提到的编码~那只能当作你编码有做到!
: 先用cli将转换过後的rtf存成档案开启看看,先确认档案正常,
: 再来判断透过http时,因为加了什麽东西造成档案开启毁损?
感谢企鹅大的指导,看来我的观念实在须要再加强,也感谢企鹅大指点了一条加强
的方向.没错,这个程式读进来的样板rtf档的确是cpg950,我也照着企鹅大上一篇
的指引将utf-8编码的中文(从mysql捞出来的)转成\uXXXXX?格式.
header的charset我也设成big5,但使用者下载回来的档案就是显示档案毁损,
无法开启.我将读档,代换,Output buffer给使用者的code,贴在下方,
希望企鹅大有空的时候看一下,指点一下问题在那里,感谢!
<?php
mysql_query("SET NAMES 'utf8'");
$result = mysql_query("select * from mytable where sn = '1'");
$row = mysql_fetch_object($result);
$title = $row->title;
$content = file_get_contents("test.rtf");
$title = str_replace(array("&", "#", ";"), array("\\", "u", "?"),
mb_convert_encoding($title, "HTML-ENTITIES", "UTF-8"));
$content = str_replace( "<<title>>", $title, $content );
header('Content-Type: text/richtext;charset=big5');
header('Content-Disposition: attachment; filename=download.rtf');
header('Content-Transfer-Encoding: binary');
header('Expires: 0');
header('Cache-Control: must-revalidate');
header('Pragma: public');
ob_clean();
flush();
echo $content;
exit;
?>
--
※ 发信站: 批踢踢实业坊(ptt.cc)
◆ From: 114.34.41.161
1F:→ mervynW:return string mb_convert_encoding... 06/04 14:16