• Tomcat+ssh+Mysql本地正常,远程服务器中文乱码。(转)


    ssh2+mysql中文乱码解决方法(统一使用UTF-8编码)

    中文乱码,首先要区分是页面乱码、action乱码,还是数据库乱码。大致的原理是java使用unicode编码– >window使用gbk(gb2312的扩展集)–mysql默认使用utf-8(unicode的一种编码方法),这样转来转去就乱码了 ^_^。解决方法如下:

    1. 在struts2里面,最好将所有字符都设成utf-8。
    <%@ page contentType=”text/html; charset=UTF-8″%>
    <%@ page pageEncoding=”UTF-8″ %>

    1.1 在jsp页面设定字符编码。这边有必有说明的是如果是jsp+java bean+servlet的方案,中文乱码很好解决,统一设成gb2312就可以了。

    1.2 使用struts框架字符集不能设成gb2312,要改成utf-8。
    2. 在struts.properties 添加:
    struts.devMode=false
    struts.enable.DynamicMethodInvocation=true
    struts.i18n.reload=true
    struts.ui.theme=simple

    struts.locale=zh_CN
    struts.i18n.encoding=UTF-8

    struts.serve.static.browserCache=false
    struts.url.includeParams=none

    其中locale、encoding就是字符集的设定了。

    3. 在web.xml加个filter[在struts2框架中,该filter必需放在Action的filter之前!顺序非常重要!!!]

    <!– zh-cn encoding –>
    <filter>
      <filter-name>EncodingFilter</filter-name>
      <filter-class>com.sterning.filter.EncodingFilter</filter-class>
      <init-param>
       <param-name>encoding</param-name>
       <param-value>UTF-8</param-value><!-- 或者你需要的编码格式 -->
      </init-param>
     </filter>
     <filter-mapping>
      <filter-name>EncodingFilter</filter-name>
      <url-pattern>/*</url-pattern>
     </filter-mapping>

    跟上述方法类似,还可以在action中设定字符编符.


    HttpServletResponse response = null;
    response = ServletActionContext.getResponse();
    request.setCharacterEncoding(”utf-8″);
    response.setContentType(”text/html;charset=utf-8″);

    通过上述方法,基本就可以搞定中文乱码的问题了。当然,也有例外(如web server的版本数据库的版本等等)。象在我的一个项目碰到一个中文乱码,tomcate5.5是会乱码的,而在tomcate6中就不会。这边就涉及到tomcate connector字符的设置了。

    <Connector port=”80″ maxHttpHeaderSize=”8192″
    maxThreads=”150″ minSpareThreads=”25″ maxSpareThreads=”75″
    enableLookups=”false” redirectPort=”8443″ acceptCount=”100″
    connectionTimeout=”20000″ disableUploadTimeout=”true” URIEncoding=”GBK” />

    ——————————————————————–

    后记之一:在使用struts2时,仍是遇到一种乱码。后来调试才发现,struts2的web.xml配置是有顺序的

    在web.xml中EncodingFilter的位置应该在Struts2的FilterDispatcher之前,因为要先调整字符集,然后进入Action。

    按照Struts2的API,filter的顺序是
    struts-cleanup filter
    SiteMesh filter
    FilterDispatcher

    ——————————————————————–

    后记之二:这个方法是下下策了,只有在前面的方法都无效时才使用。

    在action中直接使用request.getParameter()时;还是出现乱码。原因分析如下:

    1、getParameter()是有带字符参数的。例:

    String s = (String)request.getParameter(”txt”).getBytes(”iso-8859-1“);

    2、String也可以带有字符参数。

    String(byte[] bytes, String charsetName)
    构造一个新的 String,方法是使用指定的字符集解码指定的字节数组。

    例:String s = new String(”中文”,”utf-8″);

    3、综合上述两点,编写一个类来完成此项任务

    public class ConvertCharacter{

    public String Convert(String s){

    String result;

    byte[] temp ;

    try{

    temp = s.getBytes(”iso-8859-1″);

    result =  new String(temp,”utf-8″);

    }

    return result;

    }

    最后是数据库的设置:

    以mysql5为例,create db 和table时,均应该设置charset为GBK!

    总结:

    总之,你一定要保证你的字符一路走来要使用同一个编码,最好就是UTF-8.

    显示的JSP页面要用 <%@ page contentType="text/html; charset=UTF-8" language="java" %>

    struts2里设置 <constant name="struts.i18n.encoding" value="UTF-8" />

    写个FILTER 过滤一下字符,也用UTF-8

    数据库MYSQL创建的库要用UTF-8编码

    下边注意:

    在SPRING2里配置HIBERNATE的时候(MYSQL数据库),连接字符串一定要注明字符编码,否则绝对是乱码.比如我的:

    <bean id="dataSource"
      class="org.springframework.jdbc.datasource.DriverManagerDataSource">
      <property name="driverClassName"
       value="org.gjt.mm.mysql.Driver">
      </property>
      <property name="url" value="jdbc:mysql://localhost:3306/myData?useUnicode=true&amp;characterEncoding=UTF-8"></property>
      <property name="username" value="root"></property>
      <property name="password" value="root"></property>
     </bean>

    仔细看上边红色标示的部分是"&amp;",不能写成"&"符号.

    到此就成功了.

  • 相关阅读:
    [笔记]--Sublime Text 配置及使用技巧
    [笔记]--Oracle 10g在Windows 32位系统使用2G以上内存
    [笔记]--Ubuntu安装Sublime Text 2
    [笔记]--Oracle修改SGA大小
    [转载]--Ubuntu下修改DNS重启也能用的方法
    [转载]--用Python 自动安装软件
    谈谈-EventBus的使用
    谈谈-ListView的优化
    谈谈-View的事件分发机制
    谈谈-ScrollView嵌套ListView
  • 原文地址:https://www.cnblogs.com/liuxiaoke/p/4193137.html
Copyright © 2020-2023  润新知