Heim >Backend-Entwicklung >PHP-Tutorial >echo显示中文乱码的问题

echo显示中文乱码的问题

WBOY
WBOYOriginal
2016-06-23 13:55:341720Durchsuche

PHP代码如下:

echo "<li>ISBN:".$isbn."</br>书名:".$name."</br>作者:".$author."</br>";

数据由数据库中获取后赋值到$isbn。
显示乱码

加代码:
echo "<meta http-equiv='Content-Type'' content='text/html; charset=utf-8'>";

后:


怎么解决啊??


回复讨论(解决方案)

取数据之前加上:mysql_query("set names utf8");

取数据之前加上:mysql_query("set names utf8");


还是一样啊

phpmyadmin 中看到是怎样的呢?
你的数据库是用什么编码?

phpmyadmin 中看到是怎样的呢?
你的数据库是用什么编码?


utf8_general_ci

取数据之前加上:mysql_query("set names utf8");



这是代码:
//以上连接数据库mysql_set_charset("gbk");$result = mysql_query("SELECT * FROM book_list LIMIT 0 , 30" ); //查询数据库while ($bookInfo = mysql_fetch_array($result)){ //返回查询结果到数组   $isbn = $bookInfo["B_ISBN"]; //将数据从数组取出    $name = $bookInfo["B_name"];    $author = $bookInfo["B_author"];echo "<li>ISBN:".$isbn."</br>书名:".$name."</br>作者:".$author."</li>";  //输出数据}


取数据之前加上:mysql_query("set names utf8");



这是代码:
//以上连接数据库mysql_set_charset("gbk");$result = mysql_query("SELECT * FROM book_list LIMIT 0 , 30" ); //查询数据库while ($bookInfo = mysql_fetch_array($result)){ //返回查询结果到数组   $isbn = $bookInfo["B_ISBN"]; //将数据从数组取出    $name = $bookInfo["B_name"];    $author = $bookInfo["B_author"];echo "<li>ISBN:".$isbn."</br>书名:".$name."</br>作者:".$author."</li>";  //输出数据}


注释掉
//mysql_set_charset("gbk");
在echo前加上:
echo "<meta http-equiv='Content-Type'' content='text/html; charset=utf-8'>";

就好了。
而且,如果加上mysql_query("set names utf8");,全部中文都乱码了。

直接显示时,数据库读取的内容是正常的。但书名、作者乱码。
这里可以知道,你的php文件是utf8,所以加上echo "";
书名,作者这些就正常了。

然后原来读取数据库内容的变成乱码。可以肯定,数据库中的内容不是utf8格式。可用iconv转换一次看看确定问题。

// 这一句改成这样echo "<li>ISBN:".$isbn."</br>书名:".iconv('GBK','UTF-8',$name)."</br>作者:".iconv('GBK','UTF-8',$author)."</li>";  //输出数据

没事为何要加mysql_set_charset("gbk");?

难怪会这样,所以才觉得数据库里的不是UTF8

mysql_set_charset("gbk"); 等于 mysql_query("set names gbk"); 你已经转过一次,再转UTF8。。。

utf-8 编码的  书名 在 gbk 环境中会显示成  涔??
此时从数据库中读取的数据显示正常
由此可知:从数据库读取的数据是 gbk 编码的,这一点可从发出 utf-8 语言声明后,乱码情况反过来了加以佐证

按你目前的情况,你需要 $isbn = iconv('gbk', 'utf-8', $isbn); 即将读出的数据做从 gbk 到 utf-8 的编码转换
并应有 header('Content-type: text/html;charset=utf-8'); 语言声明的头

出现这种现象的原因是:
数据库为 latin1 的
字段是 utf8 的
插入是的数据是 gbk 的
由于没有在插入数据时声明字符集,所以 gbk 的内容被当做 latin1 插入到了 字段中
读出时同样也没有声明字符集,于是字段中的数据又当做 latin1 原样读回来了
其实这是很正常的,数据库本来就不该改变存储的数据
不然放进仓库的是汽车,取回时变成了摩托,那不就乱了套了吗?

对于数据库已有的数据也只有这样了,如不想放弃则需要做转码处理(很费事的)
以后再插入和读取数据时一定要注意:先执行 set names XXX 指令,注意:这个 XXX 是当前数据的字符集名
比如将 gbk 数据插入就 mysql_query("set names gbk");
将数据按 utf-8 取回就 mysql_query("set names utf8");

utf-8 编码的  书名 在 gbk 环境中会显示成  涔??
此时从数据库中读取的数据显示正常
由此可知:从数据库读取的数据是 gbk 编码的,这一点可从发出 utf-8 语言声明后,乱码情况反过来了加以佐证

按你目前的情况,你需要 $isbn = iconv('gbk', 'utf-8', $isbn); 即将读出的数据做从 gbk 到 utf-8 的编码转换
并应有 header('Content-type: text/html;charset=utf-8'); 语言声明的头

出现这种现象的原因是:
数据库为 latin1 的
字段是 utf8 的
插入是的数据是 gbk 的
由于没有在插入数据时声明字符集,所以 gbk 的内容被当做 latin1 插入到了 字段中
读出时同样也没有声明字符集,于是字段中的数据又当做 latin1 原样读回来了
其实这是很正常的,数据库本来就不该改变存储的数据
不然放进仓库的是汽车,取回时变成了摩托,那不就乱了套了吗?

对于数据库已有的数据也只有这样了,如不想放弃则需要做转码处理(很费事的)
以后再插入和读取数据时一定要注意:先执行 set names XXX 指令,注意:这个 XXX 是当前数据的字符集名
比如将 gbk 数据插入就 mysql_query("set names gbk");
将数据按 utf-8 取回就 mysql_query("set names utf8");



赞!有理有据。  分析得很好

没事为何要加mysql_set_charset("gbk");?

难怪会这样,所以才觉得数据库里的不是UTF8

mysql_set_charset("gbk"); 等于 mysql_query("set names gbk"); 你已经转过一次,再转UTF8。。。



初次接触PHP,需要连接数据库,然后度娘帮忙找到的代码。
Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn