jsp中文乱码
再谈JS乱码解决之道2010年04月09日17:21上次看到有关JS乱码解决方案,经试验有效。但部分页面仍做最后的抵抗,打死不愿意显出真身。经过百般搜索,调试。最终解决。现分享。
character_set_client客户端字符集
character_set_connection客户端与服务器端连接采用的字符集
character_set_resultsSELECT查询返回数据的字符集
character_set_database数据库采用的字符集
乱码问题一般是由于以上几个变量设置错误照成的,所以只要理解这几个变量,就可以与告别乱码了。
使用上述变量,要理解这个核心思想:character_set_client,character_set_connection这两个变量保证要与character_set_database编码的一致,而character_set_results则保证与SELECT返回的结果与程序的编码一致。
我们可以在程序中使用setnames来同时设置character_set_client,character_set_connection,character_set_results这三个系统变量。
例如setnames'utf8'等同于:
set@@character_set_client='utf8'
set@@character_set_connection='utf8'set@@character_set_results='utf8'一般情况下,当数据库与数据库表的字符集为utf8,我们再在程序里设置setnames'utf8'命令,这样就能保证无乱码了,但是,这里还要注意character_set_results变量的值,character_set_results的字符值是用来显示返回给用户的编码的。
例如,你的数据库(character_set_database)用的是utf8的字符集,那么你就要保证character_set_client,character_set_connection也是utf8的字符集。而你的程序也许采用的并不是utf8,比如你的程序用的是gbk,那么你若把character_set_results也设置为utf8的话就会出现乱码问题。此时你应该把character_set_results设置为gbk。这样就能保证数据库返回的结果与你的程序的编码一致。以下摘自网络的一程序段:
<?
//假设我们的程序采用的是utf8的字符集
$program_char='utf8';
//先检查mysql的版本号,如果版本号大于4我们才可以设置这些系统变量(mysql4还没有这些系统变量)
$version=current($db->fetch_one('SELECTVERSION()'));
if(substr($version,0,1)>4)
{
//取出当前数据库的字符集
$sql='SELECT@@character_set_database';
$char=current($db->fetch_one($sql));
//将客户端字符集(character_set_client)和连接字符集(character_set_connection)设置为与数据库字符集(character_set_database)一致
$db->query('SET@@character_set_client="'.$char.'"');
$db->query('SET@@character_set_connection="'.$char.'"');
//将SELECT查询返回数据的字符集设置为与当前程序的字符集一致
$db->query('SET@@character_set_results="'.$program_char.'"');
}
?>
1、要保证数据库中存的数据与数据库编码一致,即数据编码与character_set_database一致;
2、要保证通讯的字符集与数据库的字符集一致,即character_set_client,character_set_connection与character_set_database一致;
3、要保证SELECT的返回与程序的编码一致,即character_set_results与程序编码一致;
4、要保证程序编码与浏览器编码一致,即程序编码与<metahttp-equiv="Content-Type"content="text/html;charset=?"/>一致。
总结:在mysql中用命令:selectversion();//查看版本号
select@@character_set_client;select@@character_set_connection;select@@character_set_database;来分别查看三种编码;
若不同,则用set@@character_set_database='utf8';..来分别设置三个编码。也可直接在PHP中连接数据库函数mysql_connection()下一行用setnamesutf8来设置这三种编码的统一。
搜索返回的编码与程序文件使用编码要一致。其查询和设置方法同上。
备注:我写的一套PHP程序采用了模板技术,在所有模板页面头部上都加了如下代码:
<?header("content-type:text/html;charset=utf-8");?>
<!DOCTYPEhtmlPUBLIC"-//W3C//DTDXHTML1.0Transitional//EN""http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<htmlxmlns="http://www.w3.org/1999/xhtml">
<head>
<metahttp-equiv="Content-Type"content="text/html;charset=utf-8"/>
本以为会全部解决乱码问题,但未能如愿。仍有部分乱码,后来找到了原因,应该加在它的前一级的调用它的页面上。呵呵
[color=black][/color][size=large][/size]