phputf8乱码
。。。那是因为你的文件保存成了
GB2312编码
你把文件保存成UTF-8看下
文件默认编码是和IDE
有关的。
你从数据库获取的数据是
通过set
names
utf8
这个没问题
你META设置的是UTF-8
浏览器也知道用UTF-8
去浏览
也没问题
问题是你这个文件本身的编码要是UTF-8才行。
❷ php中用utf8编码输出中文就是乱码
header("Content-Type: text/html; charset=utf-8");
可以省略,因为在meta已经定义了。
乱码的原因是保存文件时,文件的编码与显示编码不一致,只要另存为一次就好了
❸ php连mysql用 utf-8编码乱码怎么办
1.修改my.ini:[mysql]default-character-set=utf8[mysqld]default-character-set=utf8default-storage-engine=MyISAM在[mysqld]下加入:default-collation=utf8_bininit_connect='SET
NAMES
utf8'
2.在需要做数据库操作的php程序前面加上mb_internal_encoding('utf-8');
3.create
table最后边加上ENGINE=MyISAM
DEFAULT
CHARSET=utf8
COLLATE=utf8_bin
4.phpMyAdmin/config.inc.php
$cfg['DefaultCharset']
=
'utf-8';$cfg['RecodingEngine']
=
'iconv';
5.phpMyAdmin/libraries/string.lib.php将第41行的mb_internal_encoding($GLOBALS['charset']);改为:mb_internal_encoding('utf-8');
6.phpAdmin导出数据时把"二进制区域使用十六进制显示"的勾去掉
❹ php显示数据库里的中文乱码.。ps:数据库和php显示都设置了utf8,为什么还会显示乱码求解答!!
原因:
这个是因为你的浏览默认解析编码不是 UTF-8,这种情况浏览器他不知道你的文字要显示 什么编码。
解决方案:
要么设置浏览器默认编码为 UTF-8
在输出打印前,先输出 <meta charset="utf-8">来告诉浏览器你想要使用的编码方式。
栗子:
echo '<meta charset="utf-8">';//将这行放到第一行输出
echo "<tr><><tr/>";//
❺ PHP utf-8 js 乱码
你的编码有问题,表面是UTF-8,实际可能不是。
方法:
把你现在的所有代码复制,黏贴到txt中。然后另存为。在txt的另存界面
看到编码了么?选择UTF-8;另外ANSI就是电脑默认编码,中国的话都是GB-2312;
用txt重新整理一下编码就不会乱码了~
❻ php与数据库中,都是用的utf8编码,但还是乱码
你的php代码还有请求头的编码和响应头的编码也都要统一成utf8,只控制数据库的编码不行的
❼ php 有关utf-8乱码的问题
服务器上用了别的编码,应该是windows的服务器吧?有可能是GBK或者GB2312编码。
两种方法解决此问题。
1、先在本地把所有文件都换成服务器的编码,然后再传上去;此法,你的php编码需要与服务器上的数据库编码一致,也既有可能是那两种编码。
2、修改服务器上的编码为utf-8。此方法需要你有足够的权限去修改服务器上apache或者IIS编码。如果修改编码成功,你的数据库也不用换编码。
如果保持你的网页编码不变,那就要修改mysql编码,即像stjdydayou
所言,执行数据库数据插入、更改、查询时,执行一条查询语句:
mysql_query("set
names
'utf-8'");
之所有用utf-8编码,是因为你的php编码目前为utf-8.
❽ PHP已经声明是utf8编码了,为什么浏览器识别不出来,还是乱码
php的文件用记事本打开,然后点击另存,选择utf-8编码后保存
❾ PHP使用utf8插入中文数据到MySQL中文显示会乱码怎么办
数据库使用utf8编码,需要在操作的过程中统一全部编码。
1.数据库默认编码
CREATEDATABASE`test`DEFAULTCHARACTERSET'utf8';
2.表默认编码
CREATETABLE`tablea`(
`id`INTNOTNULLAUTO_INCREMENT,
`title`VARCHAR(100)NULL,
)ENGINE=InnoDBDEFAULTCHARSET=utf8;
3.字段默认编码
默认情况下,字段的编码同表的编码,但是如果修改了表的编码,字段编码不会同步修改,需要手动修改
这里修改编码测试我将utf8 改为 gb2312 ,仅用于观察修改后的情况(实际使用中可能是将gbk修改为utf8)
ALTERTABLE`test`.`tablea`CHARACTERSET=gb2312;
--修改表编码后,查看建表语句
showcreatetable`tablea`;
--可以看到输出的建表语句中字段单独设置了编码
CREATETABLE`tablea`(
`id`INTNOTNULLAUTO_INCREMENT,
`title`VARCHAR(100)CHARACTERSETutf8NULL,
)ENGINE=InnoDBDEFAULTCHARSET=gb2312;
--需要手动修改字段编码
ALTERTABLE`tablea`
CHANGECOLUMN`title``title`VARCHAR(100)CHARACTERSET'gb2312'NULLDEFAULTNULL;
4.当前数据库连接的编码
连接数时设置编码
//PDO连接
$db=newPDO('mysql:host=myhost;dbname=test','login','password',
array(PDO::MYSQL_ATTR_INIT_COMMAND=>'SETNAMES'UTF8'')
);
//mysqli连接
$link=mysqli_connect("127.0.0.1","my_user","my_password","test");
mysqli_query($link,"SETNAMES'utf8';");
通过以上几步操作,基本可以保证数据库使用过程中不会出现乱码
❿ php设置成utf-8还是乱码了怎么办
有时后php代码里边设置了“header("Content-type:
text/html;
charset=utf-8");”不一定会管用,因为有时文件本身格式就是错误的,你先把代码复制到一个txt文件里边,然后用代码工具对php文件进行转码成utf-8格式(这时你就会发现里边的代码乱码了,由其是中文和特殊字符),再把txt里边的代码复制覆盖原来的php文件内容,然后保存即可,例如用Notepad++
工具
可以对文件本身进行转码