通过ucenter整合不同编码dedecms和论坛的方法
今天模板遇到一个客户是要整合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='.urlencode('<a href="{url}" target="_blank">{title}</a>').'&'.
[*] 'apptagtemplates='.urlencode('标题').'&'.
[*] 'apptagtemplates='.urlencode('作者').'&'.
[*] 'apptagtemplates='.urlencode('时间').'&'.
[*] 'apptagtemplates='.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='.urlencode('<a href="{url}" target="_blank">{title}</a>').'&'.
[*] 'apptagtemplates='.urlencode(utf82gb('标题')).'&'.
[*] 'apptagtemplates='.urlencode(utf82gb('作者')).'&'.
[*] 'apptagtemplates='.urlencode(utf82gb('时间')).'&'.
[*] 'apptagtemplates='.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) && !strstr($this->fields['face'],UC_API))
[*] {
[*] $this->fields['face'] = UC_API.'/avatar.php?uid='.$data.'&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{{
一般就是API调用开始。这个因为要修改的东西比较多。略过。高手应该可以举一反三。主要问题就解决了!
页:
[1]