您的位置:首页 > 编程语言 > Java开发

struts2中文乱码问题

2017-08-19 17:33 405 查看
(一)中文乱码,首先要区分是页面乱码、action乱码,还是数据库乱码。

大致的原理是java使用unicode编码-->window使用gbk(gb2312的扩展集)--mysql默认使用utf-8(unicode的一种编码方法),这样转来转去就乱码了

(1)页面中文乱码

对于在页面中显示出现乱码,这个问题比较简单,便是检查你的JSP文件中是不是出现了中文要处理。由于JSP默认的编码格式为“ISO-8859-1”。

jsp代码:<%@ page language="java" import="java.util." pageEncoding="ISO-8859-1">  

改成:

jsp代码:<%@ page language="java" import="java.util." pageEncoding="UTF-8"> 
 (推荐)

<%@
page language="java"
contentType="text/html;
charset=UTF-8" pageEncoding="UTF-8"%>

<%@ page language="java" import="java.util.*"contentType="text/html;
charset=UTF-8" %>

HTML代码:在<head>标签中添加:<metacharset="utf-8">
pageEncoding
在JSP标准的语法中,如果pageEncoding属性存在,那么JSP页面的字符编码方式就由pageEncoding决定,否则就由contentType属性中的charset决定,如果charset也不存在,JSP页面的字符编码方式就采用默认的ISO-8859-1。

pageEncoding是jsp文件本身的编码
contentType的charset是指服务器发送给客户端时的内容编码

(2)传递参数乱码
在form表中中文乱码直接设置constant
1、在struts.xml中设置默认字符集:<constant name="struts.i18n.encoding" value="UTF-8" />
或者   在struts.properties中设置:struts.i18n.encoding=UTF-8 
constant要与jsp页面的字符编码一致,可以统一设置为UTF-8,这样乱码问题就可以解决
2、如果使用了spring可以在web.xml中添加字符集过滤器filter,因为拦截有顺序,该过滤器必须放在最前面

<filter>

  <filter-name>characterEncodingFilter</filter-name>

  <filter-class>org.springframework.web.filter.CharacterEncodingFilter</filter-class>

  <init-param>

    <param-name>encoding</param-name>

    <param-value>UTF-8</param-value>

  </init-param>

  <init-param>

    <param-name>forceEncoding</param-name>

    <param-value>true</param-value>

  </init-param>

</filter>

<filter-mapping>

  <filter-name>characterEncodingFilter</filter-name>

  <url-pattern>/*</url-pattern>

</filter-mapping>

也可以在action中设置字符编码

HttpServletResponseresponse = null;
   response
=ServletActionContext.getResponse();
   request.setCharacterEncoding("utf-8");
   response.setContentType("text/html;charset=utf-8");

3、url中文参数乱码以上方法不行,直接设置tomcat中conf文件夹下的server.xml文件。

1和2都只能设置post方式提交数据的编码方式,如果url有中文的话就会有乱码,解决办法是在

tomcat的\conf\server文件的


添加 URIEncoding="UTF-8"。如果你正在使用eclipse,记得重启eclipse,把服务器的设置删除,重新设置。

1、Filter接口:



三个方法说明:

*public void init(FilterConfig filterConfig)throws ServletException//过滤器初始化方法,此方法在过滤器初始化时被调用

*public void doilter(ServletRequest request , ServletResponse response,FilterChain chain)throws IOException, ServletException//对请求进行过滤 处理

*public void destroy();//销毁方法,以便释放资源

2、FilterConfig接口



 

*public Strng getFilterName();//用于获取过滤器的名字

*public ServletContext getServletContent();//获取Servlet上下文

*public String getInitParameter(String name);//获取过滤器的初始化参数值

*public Enumeration getInitParameterNames();//获取过滤器的所有初始化参数

[5]FilterChain接口

public void doFilter(ServletRequest request request, ServletResponse response)throws IOException , ServletException

3、自定义过滤器

import java.io.IOException;  

  

import javax.servlet.Filter;  

import javax.servlet.FilterChain;  

import javax.servlet.FilterConfig;  

import javax.servlet.ServletException;  

import javax.servlet.ServletRequest;  

import javax.servlet.ServletResponse;  

  

public class CharactorFilter implements Filter {  

    // 字符编码  

    String encoding = null;  

    public void destroy() {  

        encoding = null;  

    }  

    public void doFilter(ServletRequest request, ServletResponse response,  

            FilterChain chain) throws IOException, ServletException {  

        // 判断字符编码是否为空  

        if(encoding != null){  

            // 设置request的编码格式  

            request.setCharacterEncoding(encoding);  

            // 设置response字符编码  

            response.setContentType("text/html; charset="+encoding);  

        }  

        // 传递给下一过滤器  

        chain.doFilter(request, response);  

    }  

    public void init(FilterConfig filterConfig) throws ServletException {  

        // 获取初始化参数  

        encoding = filterConfig.getInitParameter("encoding");  

    }  

}  

4、过滤器在web.xml中的配置

<!-- 声明过滤器 -->  

    <filter>  

        <!-- 过滤器名称 -->  

        <filter-name>CharactorFilter</filter-name>  

        <!-- 过滤器的完整类名 -->  

        <filter-class>com.lyq.CharactorFilter</filter-class>  

        <!-- 初始化参数 -->  

        <init-param>  

            <!-- 参数名 -->  

            <param-name>encoding</param-name>  

            <!-- 参数值 -->  

            <param-value>UTF-8</param-value>  

        </init-param>  

    </filter>  

    <!-- 过滤器映射 -->  

    <filter-mapping>  

        <!-- 过滤器名称 -->  

        <filter-name>CharactorFilter</filter-name>  

        <!-- URL映射 -->  

        <url-pattern>/*</url-pattern>  

    </filter-mapping>  

(4)从数据库取值乱码:比如mysql,确认你的数据库内字符是gbk,并且连接字符串指定了字符编码
<property name="url" value="jdbc:mysql://localhost/database?useUnicode=true&characterEncoding=gbk"></property>

(5)在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 classConvertCharacter{

       public String Convert(String s){

           String result;

           byte[] temp ;

           try{

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

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

           }

           return result;

       }

   }
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: