| 
  今天模板遇到一个客户是要整合dedecms和论坛,但是发现dedecms和论坛和uc的编码却不是一样的,我以DEDECMS5.6 UTF8  与UCENTER Gbk  和UCHOME GBK 为例。 先在后台安装DEDECMS5.6 UTF8 安装UCENTER 模块。 打开管理目录下的api_center.php 第一步:删除安装UC插件提示“uc服务端编码与DedeCMS编码不一致!要求您的uc服务端编码为:gbk编码.”并且对传递的网站名称,标签模板标记说明:UTF8转GBK 查找:  
 
- elseif($ucdbcharset != 'gbk')   
 -             {   
 -                 ShowMsg('uc服务端编码与DedeCMS编码不一致!要求您的uc服务端编码为:gbk编码.',-1);   
 -                 exit();    
 -             }   
 -             //标签应用模板   
 -             $app_tagtemplates = 'apptagtemplates[template]='.urlencode('<a href="{url}" target="_blank">{title}</a>').'&'.   
 -             'apptagtemplates[fields][title]='.urlencode('标题').'&'.   
 -             'apptagtemplates[fields][writer]='.urlencode('作者').'&'.   
 -             'apptagtemplates[fields][pubdate]='.urlencode('时间').'&'.   
 -             'apptagtemplates[fields][url]='.urlencode('地址');   
 -                
 -             $postdata = 'm=app&a=add&ucfounder=&ucfounderpw='.urlencode($uc_setings['authkey']).'&apptype=OTHER&appname='.urlencode($GLOBALS['cfg_webname']).'&appurl='.urlencode($GLOBALS['cfg_basehost']).'&appip=&appcharset=gbk&appdbcharset=gbk&'.$app_tagtemplates.'&release='.UC_CLIENT_RELEASE;  
 
 
  
 |  
  
修改为  
- //elseif($ucdbcharset != 'gbk')   
 -             //{   
 -             //  ShowMsg('uc服务端编码与DedeCMS编码不一致!要求您的uc服务端编码为:gbk编码.',-1);   
 -             //  exit();    
 -             //}   
 -             //标签应用模板   
 -             $app_tagtemplates = 'apptagtemplates[template]='.urlencode('<a href="{url}" target="_blank">{title}</a>').'&'.   
 -             'apptagtemplates[fields][title]='.urlencode(utf82gb('标题')).'&'.   
 -             'apptagtemplates[fields][writer]='.urlencode(utf82gb('作者')).'&'.   
 -             'apptagtemplates[fields][pubdate]='.urlencode(utf82gb('时间')).'&'.   
 -             'apptagtemplates[fields][url]='.urlencode(utf82gb('地址'));   
 -                
 -             $postdata = 'm=app&a=add&ucfounder=&ucfounderpw='.urlencode($uc_setings['authkey']).'&apptype=OTHER&appname='.urlencode(utf82gb($GLOBALS['cfg_webname'])).'&appurl='.urlencode($GLOBALS['cfg_basehost']).'&appip=&appcharset=gbk&appdbcharset=gbk&'.$app_tagtemplates.'&release='.UC_CLIENT_RELEASE;  
 
 
  
 |  
  
完成上面这一步就可以开始配置UCENTER模块了。 第二步:解决在UCENTER HOME GBK 或其他GBK 版本注册中文用户名在DEDECMS乱码问题。 打开api/uc.php 查找 - function synlogin($get, $post)   
 -     {   
 -         $uid = $get['uid'];   
 -         $username = $get['username'];
 
 
  |  
  
修改为(对UC里的中文用户名从GBK转换成UTF8)  
- function synlogin($get, $post)   
 -     {   
 -         $uid = $get['uid'];   
 -         $username = gb2utf8($get['username']);  
 
 
  
 |  
  
这样可以解决中文用户名乱码的问题。但是还有一个很严重的问题。后台所有关于数据库方面的都乱码。 个人以为是每次使用API的时候。DEDECMS都延续了UCenter的MYSQL采用的编码。 所有我们要再每次API调用后再指定DEDECMS的采用的编码。  
 mysql_query("SET NAMES 'utf8'");  
  |  
  
同步登陆同步登出相关最重要的是:include/memberlogin.class.php 打开它 查找  
 - #api{{   
 -                 if(defined('UC_API') && @include_once DEDEROOT.'/uc_client/client.php')   
 -                 {   
 -                     if($data = uc_get_user($this->fields['userid']))   
 -                     {   
 -                         if(uc_check_avatar($data[0]) && !strstr($this->fields['face'],UC_API))   
 -                         {   
 -                             $this->fields['face'] = UC_API.'/avatar.php?uid='.$data[0].'&size=middle';   
 -                             $dsql->ExecuteNoneQuery("UPDATE `dede_member` SET `face`='".$this->fields['face']."' WHERE `mid`='{$this->M_ID}'");   
 -                         }   
 -                     }   
 -                 }   
 -                 #/aip}}  
 
 
  |  
  
后面插入一行 |  mysql_query("SET NAMES 'utf8'");  |  
  
这样就可以解决从UCenter接收的中文乱码。 还有就是文章推送,短消息同步在保存到UCENTER的时候就必须转换成GBK编码。并且在API结束后再把默认MSYQL编码转换回DEDECMS默认编码。 你可以全目录查找一下代码:  
 
一般就是API调用开始。这个因为要修改的东西比较多。略过。高手应该可以举一反三。主要问题就解决了!  
 |