永远的学生

qindgfly

导航

zen-cart 乱码问题总结

在使用zen-cart制作多国语言的电子商务网站时,经常会遇到乱码问题,下面做一个总结。

 1. 数据库造成的乱码问题。在后台录入数据时和前台展示时,页面的编码不一致可能导致该问题。例如后台管理录入数据时使用的编码为utf-8,而前台显示时,编码为iso-8859-7,则会产生乱码。解决办法,将后台语言包中的charset设置为 iso-8859-7,或者将前台语言包中的charset设置为 utf-8。对单语种的站点可以采取这种方式解决。

 

 2. 对于多语种的站点,若直接将站点的编码修改为 iso-8858-7,则有可能会导致其他语言的乱码问题。例如:希腊的编码为 iso-8858-7,土耳其的编码为 iso-8858-9,若在希腊环境下编辑产品信息,则此时录入数据库时的编码为 iso-8858-7,土耳其语言也被迫以 iso-8858-7的编码录入数据库,而在前台又不得不以 iso-8858-9的编码来展示土耳其语言,这样以来土耳其语言就可能出现乱码。解决办法,多余多语种的站点,全部采取 utf-8的编码格式。

 

 3. 采取utf-8编码格式后,因为一般从网上下载下来的语言包中的文件都不是utf-8格式,可能也会导致一部分语言出现乱码。所以,最好将下载下来的语言包全部转化为utf-8文件格式,你可以用文本编辑器,dreamweaver,或者其他编辑器将语言包中的每个文件转化为 utf-8 格式。如果觉得麻烦的话,可以下载一个文件编码批量转化工具(EncodingConvertor),该工具可以将一个文件夹中所有的文件进行编码转化。转化的时候要注意,原编码一定要选择正确,如果不知道原编码的话,打开语言包中的 language.php(请将language替换为语言名字,如english.php,greek.php), 看看CHARSET的定义是什么。

 

4. 将编码转化为 utf-8后,可能会导致页面比较错了的现象,这是因为文件以utf-8格式保存时,自动在文件开头加上了一个 unicode签名(BOM, Byte Order Mark), 这是三个不可见的字符(0xEF 0xBB 0xBF),用于让一些编辑软件(如记事本)知道这个文件是 以 utf-8编码的。php在 require以utf-8编码的文件时,却没有能够忽略这几个字符,结果导致这几个字符作为输出的一部分。这时若要时网页布局正常,则需要将这个BOM去掉,用dreamweaver打开文件,按 ctrl+J,在标题/编码选项卡中取消选中“包括Unicode签名”,再保存。也可以使用下面的代码来批量处理一个文件夹中的BOM(将下面的文件放到根目录,在浏览一下就可以了)。 

 

 

代码
<?php
//此文件用于快速测试UTF8编码的文件是不是加了BOM,并可自动移除
//By Bob Shen

require('includes/application_top.php');
$basedir= DIR_FS_CATALOG. 'includes/languages'//修改此行为需要检测的目录,点表示当前目录
$auto=1//是否自动移除发现的BOM信息。1为是,0为否。
handler($basedir);
function handler($dir){
    
global $auto;
    
    
if($dh = opendir($dir)){
        
while (($file = readdir($dh)) !== false) {
            
if ($file!='.' && $file!='..') {
                
if(!is_dir($dir."/".$file)){
                    
echo "filename: $dir/$file ".checkBOM("$dir/$file")." <br>";
                }
                
else{
                    handler(
$dir."/".$file);
                }
            }            
        }
        
closedir($dh);
    }
}
function checkBOM ($filename) {
    
global $auto;
    
$contents=file_get_contents($filename);
    
$charset[1]=substr($contents, 0, 1);
    
$charset[2]=substr($contents, 1, 1);
    
$charset[3]=substr($contents, 2, 1);
    
if (ord($charset[1])==239 && ord($charset[2])==187 && ord($charset[3])==191) {
        
if ($auto==1) {
        
$rest=substr($contents, 3);
        rewrite (
$filename, $rest);
        
return ("<font color=red>BOM found, automatically removed.</font>");
        } 
else {
        
return ("<font color=red>BOM found.</font>");
        }
    }
        
else return ("BOM Not Found.");
    }

function rewrite ($filename, $data) {
    
$filenum=fopen($filename,"w");
    
flock($filenum,LOCK_EX);
    
fwrite($filenum,$data);
    
fclose($filenum);
}
?>

 

按照以上步骤处理后,一般就不会发现乱码了。

posted on 2010-01-07 16:56  东国先生  阅读(2017)  评论(0编辑  收藏  举报