一开始使用的是mysql,数据库的编码是UTF-8

后来换数据库,mysql换成mssql2005,数据库编码为GBK,管理菜单出现乱码,如下所示(左图正常,右图乱码)

解决方法如下:

第一,查看数据库,找到数据表:ch_node,找到需要进行转码的字段

第二,打开 “ 项目名/Admin/Lib/Action/UiAction.class.php”

在  public function menu($from='') {} 中,将读取出来的中文字段进行转码

如上图,添加红色框标志的中文转码后,保存,刷新界面,正常显示了。

如果是“文章管理”的下一级栏目乱码,如图红框部分是乱码显示的情况!@_@~

看下数据库,数据表 ch_category,找到需要进行转码的字段,

^_^ 还是进行转码处理!!

打开 项目名/Admin/Lib/Model/CategoryModel.class.php

找到下面这个函数:

public function tree($map=array('classpid'=>0),$link='',$selparent=''){}

修改如下:

public function tree($map=array('classpid'=>0),$link='',$selparent=''){
$return = '';
if($link==''){
if($_REQUEST['cid']!='' || $_REQUEST['cname']!=''){ //附加“清空”按钮
$return .= '<ul class="tree treeFolder">';
$return .= ' <li><a href="javascript:;" style="color:red" onclick="$(\'#'.$_REQUEST['cid'].'\').val(\'\');$(\'#'.$_REQUEST['cname'].'\').val(\'\');">清空重置</a></li>';
$return .= '</ul>';
}
}
$list = M('Category')->field('classid,classpid,classtitle,classchild,classarrchildids, classmodule')->where($map)->select();
if($list){
if($link=='info_addview'){
$return .= '<ul>';
}else{
$return .= '<ul class="tree treeFolder expand collapse">';
}
foreach($list as $rs){
if($rs['classpid']==0){
if($link=='edit'){
$strlink =
'<a class="edit" href="__APP__/Category/edit/classid/'.$rs['classid'].'" target="dialog" width="700" height="550" rel="'.$rs['classid'].'">'.iconv('GBK','UTF-8',$rs['classtitle']).'</a>';
}elseif($link=='info_addview'){
$strlink =
'<a class="info_addview" href="__APP__/'.$rs['classmodule'].'/index/tid/'.$rs['classid'].'" target="navTab" rel="'.$rs['classmodule'].'">'.iconv('GBK','UTF-8',$rs['classtitle']).'</a>';
}else{
$strlink =
'<a href="javascript:;"'.(($selparent || !$rs['classchild']) ? ' onclick="selectClass(\''.$rs['classid'].'\',\''.iconv('GBK','UTF-8',$rs['classtitle']).'\');"' : '').'>'.iconv('GBK','UTF-8',$rs['classtitle']).'</a>';
}
if($rs['classchild']==0){
$return .= '<li>'.$strlink.'</li>';
}else{
$return .= '<li>'.$strlink;
$return .= $this->_for_tree($rs['classarrchildids'], $link, $selparent);
$return .= '</li>';
}
}
}
$return .= '</ul>';
}
return $return;
}

这样就不会出现乱码啦。如果有别的菜单栏目需要转码,也是按照上面的做法,找到相应的代码文件,进行代码修改。

(^_^)~   完~

thinkphp -- 解决连接mssql后台管理菜单显示中文乱码问题(备忘)的更多相关文章

  1. 解决django的后台管理界面添加中文内容乱码问题

    在使用django migrate功能时,默认数据库的字符集不是utf8. 是latin 1,然后在后台管理model时,不允许有中文字符插入 解决方案: 在使用migrate建库之前先把数据库建立起 ...

  2. kali 解决Metasploit拿到shell后显示中文乱码问题

    拿到对方shell后显示的问题如下: 中文乱码解决: chcp 65001 然后 上传下载文件

  3. django 1.10.3 admin后台管理设置显示中文

    在网上搜索的什么设置settings.py的LANGUAE_CODE,在1.10.3下完全不行,直接报错,后来使用了django.middleware.locale.LocaleMiddleware才 ...

  4. XFTP连接主机文件名显示中文乱码且不能下载的解决方法

    Xftp连接主机文件名显示中文乱码且不能下载的本地解决方法 原因:Xftp编码格式问题 解决方法:把Xftp的编码格式增加UTF-8 具体步骤:打开Xftp,文件-属性,在打开的属性界面中打开&quo ...

  5. XShell连接 Linux系统,显示中文乱码

    摘要: Linux系统,中文显示乱码 XShell是一个强大的安全终端模拟软件,它支持SSH1, SSH2及 Microsoft Windows平台的Telnet NetSarang Xshell 4 ...

  6. RoportNG报表显示中文乱码和TestNG显示中文乱码实力解决办法

    最近在进军测试自动化框架学习阶段,但无意间总是会伴随小问题的困扰,比如中文乱码,而导致显示总是不舒服,个人觉得,就一定要解决,似乎有点点强迫症.所以遇到RoportNG报表显示中文乱码和TestNG显 ...

  7. ReportNG报表显示中文乱码和TestNG显示中文乱码实力解决办法

    最近在进军测试自动化框架学习阶段,但无意间总是会伴随小问题的困扰,比如中文乱码,而导致显示总是不舒服,个人觉得,就一定要解决,似乎有点点强迫症.所以遇到ReportNG报表显示中文乱码和TestNG显 ...

  8. secureCRT linux shell显示中文乱码 解决方法

    引:有没有这样的经历: 1.在shell中直接查看包含中文的文件时,出现一堆火星文,不得不下载下来window看. 2.无法正常的在shell中输入中文. 3.make的时候输出一堆乱码. 以下是查阅 ...

  9. Win 7英文系统显示中文乱码的解决(转)

    Win 7英文系统显示中文乱码的解决http://www.enet.com.cn/article/2011/0811/A20110811896633.shtml 请点击Startmenu并点击Cont ...

随机推荐

  1. python继承

    Python继承 继承实例: 父类和子类的关系: 继承树: 没有父类就继承object类,不要忘记调用super().__init__来初始化父类 代码: class Person(object): ...

  2. MySQL完整性语言

    文章为作者原创,未经许可,禁止转载.    -Sun Yat-sen University 冯兴伟 实验3:完整性语言 完整性语言实验包含3个实验项目,其中2个必修项目,1个选修项目.该实验的各个实验 ...

  3. [原创]Java静态代码检查工具介绍

    [原创]Java静态代码检查工具介绍 一  什么是静态代码检查? 静态代码分析是指无需运行被测代码,仅通过分析或检查源程序的语法.结构.过程.接口等来检查程序的正确性,找出代码隐藏的错误和缺陷,如参数 ...

  4. XCode打包脚本

    #!/bin/bash #for debug#请将 TARGET-NAME 改成项目的 TARGET 名称#放置于 .xcodeproj 同级目录中执行 target_name="xx&qu ...

  5. 通过生产者消费者模式例子讲解Java基类方法wait、notify、notifyAll

    wait(),notify()和notifyAll()都是Java基类java.lang.Object的方法. 通俗解释wait():在当前线程等待其它线程唤醒.notify(): 唤醒一个线程正在等 ...

  6. Android webView打不开网页的解决办法

    在我们开发过程中,有可能会遇到webview有些网页打不开的问题.这可能是设置的不对,下面就是解决办法. 进行如下设置吧,大多数情况都能解决! displayWebview.getSettings() ...

  7. 免安装版MySQL安装步骤

    http://downloads.mysql.com/archives/community/ 1:添加环境变量把MySQL解压后的bin目录添加到path环境变量中 2:修改或者添加my-defaul ...

  8. IOS开发 应用程序图标数字角标

    其实实现这个功能很简单,只要调用UIApplication即可.   用法用例:[UIApplication sharedApplication].applicationIconBadgeNumber ...

  9. 使用Eclipse进行远程调试【转】

    今天决定做件有意义的事,写篇图文并茂的blog,为什么要图文并茂?因为很多事可能用语言也说不明白,从以前我发表的一篇文章可以看得出来,http://blog.csdn.net/sunyujia/arc ...

  10. ubuntu系统中的VMware 安装win7 Ghost镜像的几个坑

    1.ghost镜像安装时要先分区 2.分区后要激活 3.VM(虚拟机安装win7 提示 :units specified don't exist, SHSUCDX can't install)解决方法 ...