php文件名不克不及中文的处理方法:起首将网页用utf-8编码以及保留;而后将fopen里的文件名参数经过iconv函数独自进行编码便可防止中文文件名乱码。
保举:《PHP视频教程》
php中fopen不克不及创立中文文件名文件的成绩
以前网页的chartset用的是utf-8,文件也用utf-8,而后用fopen()创立一个中文文件名的文件时成绩就进去了,文件名都是乱 码!
查看了不少文档试了很多办法都处理没有了,原本想着用此外办法绕过这个成绩,突然脑筋里闪过Windows默许的文字编码是ansi,而后再 百度了一下,证明了这点,以是我的网页也应该是ansi编码能力使创立的文件名没有会是乱码。
接着就着手验证,把网页都用ansi保留,去掉chartset语句,果真ok了,然而网页的内容就成乱码了,起初想起,这个网页还include 了此外网页,把include的网页也改为ansi保留,哈哈万事ok
编程这个工作真的很靠积攒,假如我之前没看过Windows默许编码是ansi,那这个成绩就没有知何年何月能力处理了
ps:< meta content ="text/html; charset=utf-8" http -equiv ="Content-type" > 这个meta标志肯定要放正在<title></title>以前才无效的
起初又想到了一个更好的处理办法,网页仍是用utf-8编码以及保留,只是fopen()里的文件名参 数独自给它编下码就行,php有iconv() 这个更换编码的顺序,把utf-8转成 gb2312就能够防止中文文件名为乱码了
test.htm
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd"> <html> <head> <meta content="text/html; charset=UTF-8" http-equiv="Content-Type"> <title>题目:{title}</title> </head> <body> <b>此旧事的内容:</b>{content} </body> </html>
test.php
<?php //实际使用中极可能是查问数据库取内容。 $rows = array(array("交换题目1","交换内容1"),array("交换题目2","交换内容2")); $filename = "tmp.htm"; foreach($rows as $id => $val){ $title = $val[0]; $content = $val[1]; $pagename = "测试".$id.".html"; //对文件名的编码,防止中文文件名乱码 $pagename = iconv("UTF-8", "GBK", $pagename); //读取模板 $tmpfile = fopen($filename,"r"); $string = fread($tmpfile,filesize($filename)); $string = str_replace("{title}",$title,$string); $string = str_replace("{content}",$content,$string); fclose($tmpfile); //写新文件 $newpage = fopen($pagename,"w"); fwrite($newpage,$string); fclose($newpage); } echo "创立胜利!"; ?>
以上就是若何处理php文件名不克不及中文的成绩的具体内容,更多请存眷资源魔其它相干文章!
抱歉,评论功能暂时关闭!