Maison  >  Article  >  développement back-end  >  PHP读取目录含特殊字符会变成?怎么将让MYSQL正确显示插入的UTF8编码数据

PHP读取目录含特殊字符会变成?怎么将让MYSQL正确显示插入的UTF8编码数据

WBOY
WBOYoriginal
2016-06-13 12:29:38976parcourir

PHP读取目录含特殊字符会变成?,如何将让MYSQL正确显示插入的UTF8编码数据
123.txt文件编码UTF8,浏览器页面编码UTF8,Windows系统,代码页936
新建文件夹内只有一个文件夹,文件名为http://zhidao.baidu.com/link?url=9iTctYWxBKDqzxTH-QrBs5t6Q9lhRkutHCfJHaGRNlzsswkqWsnYLdtKfCk7F_AJQwMm2yxJmoOCLDGipSjr-a这里的爱心,CSDN不让直接发出来=。=

<br />
<?php<br />
	$path = iconv("UTF-8", "GBK", "F:/新建文件夹/");<br />
	$dir = dir($path);<br />
	$fopen = fopen("F:/123.txt", "a");<br />
	<br />
	while ($file = $dir->read()) {<br />
		if ($file != "." && $file != "..") {<br />
			$file = iconv("GBK", "UTF-8", $file);<br />
			echo $file;<br />
			//fwrite($fopen, $file));<br />
		}<br />
	}<br />
	fclose($fopen);<br />
?><br />

不论是echo输出在浏览器还是保存到123.txt中,都显示的是?。
1、我试过is_dir($path.$file);显示空,所以我估计这个问号不是显示问题而是read()时windows返回的就是ASCII的?,请问要正常读取应该如何解决?
2、另外要将UTF8编码的数据存储到MYSQL中,而且要求在MYSQL中不显示乱码,请问MYSQL中数据库、表和列的数据类型和排序类型应该如何选择?
谢谢!我看你的程序
1.$fopen没有使用到,创建的目的是什么?
2.is_dir($path.$file);显示空,因为is_dir是判断是否目录,而$path.$file是文件,因此返回false。

如果只是需要读出123.txt的内容显示,可以这样写。
<br />
<?php<br />
$path = iconv("UTF-8", "GBK", dirname(__FILE__).'/新建文件夹/');<br />
$file = '123.txt';<br />
<br />
echo '<meta http-equiv="content-type" content="text/html; charset=utf-8">';<br />
echo file_get_contents($path.$file);<br />
?><br />

关键是 这句,设置页面编码。


2.如果要数据库保存不乱码,可以设置mysql
character_set_client:客户端来源数据使用的字符集
character_set_connection:连接层字符集
character_set_results:查询结果字符集
为utf8,
关于mysql 编码设置可以参考 http://blog.csdn.net/fdipzone/article/details/18180325
这个与编码没有什么关系吧?

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn