Struts中文乱码的解决方法

在进行struts开发的过程中。总也是出现非常多的乱码问题。但归根究竟,也仅仅是下面三种情况: 

㈠页面显示中文乱码 

㈡传递參数中文乱码 

㈢国际化资源文件乱码
 

以下就这三中情况介绍怎么在详细项目中处理这些乱码问题。

而对于总体的处理思想。是要统一编码为: UTF-8.(以myeclipse6支持的struts1.3为准) 

㈠页面显示中文乱码 

      对于在页面中显示出现乱码,这个问题比較简单,便是检查你的JSP文件中是不是出现了中文要处理。由于JSP默认的编码格式为“ISO-8859-1”。当JSP中出现要处理的中文时。其显示就出现乱码了,这样的情况一般出如今手写JSP,或改动时。由于在myeclipse6.0中,假设出现了编码错误时,程序不会让你保存,而是会提示你注意编码,这点非常好。

详细的改动办法是把

Html代码

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


改成:

Html代码 

<%@ page language="java" import="java.util." pageEncoding="UTF-8"> 


㈡传递參数中文乱码 

         传递參数出现的乱码,參数的内容为中文。比方在struts应用中,简单的一个登录界面中。须要传递的登录名为中文时,你没经处理之前,是会出现乱码传递的。为了让我们能看到显示的乱码,我们在相应的Action类的子类里,改动一下。用System.out把接受到的參数输出,代码例如以下:

Java代码

public ActionForward execute(ActionMapping mapping, ActionForm form, HttpServletRequest request,   
        HttpServletResponse response) ...{   
    DynaActionForm loginForm = (DynaActionForm) form;   
  
    String username = (String) loginForm.get("username");   
    String password = (String) loginForm.get("password");   
    System.out.println("username:"+username);   
    System.out.println("password:"+password);   
    if (username.equals("ivorytower") && password.equals("123456")) ...{   
        return mapping.findForward("success");   
    }   
    return mapping.findForward("fail");   
    }  


那么当你提交了中文输入后就会出现乱码了。 

详细的解决方法: 

①改动Tomcat---->conf----->server.xml文件,在改动port的标签后面加一行代码。例如以下:

Xml代码

port="8080" protocol="HTTP/1.1"    
              connectionTimeout="20000"    
              redirectPort="8443"  URIEncoding="UTF-8"/>  


②编写过滤器Filter

Java代码

    

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 CharacterEncodingFilter implements Filter ...{   
    String charSet; //保存编码参数
    @Override  
    public void destroy() ...{   
    }   
  
    @Override  
    public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain) throws IOException,ServletException   {   
    		request.setCharacterEncoding(charSet); //xml初始化函数中赋值过了,后面给出web.xml代码
		HttpServletRequest req=(HttpServletRequest) request;
		HttpServletResponse resp=(HttpServletResponse) response;
		HttpSession ses=req.getSession();   //HttpSession!
		if(ses.getAttribute("username")!=null) {
			chain.doFilter(request, response);
		}else {
			//request.getRequestDispatcher("/login/login.html").forward(request,response);
			resp.sendRedirect("/login/login.html");  //跳转之后再登陆404
		}
		// pass the request along the filter chain
		//chain.doFilter(request, response);
    }   
  
    @Override  
    public void init(FilterConfig arg0) throws ServletException {   
    }   
  
}  


  利用过滤器,把request传递的中文參数都设成“UTF-8”编码。 

然后web.xml文件配置过滤器

    打开项目里的web.xml文件,在前面加上例如以下代码:

Xml代码

<filter>
    <filter-name>Login</filter-name>
    <filter-class>filter.LoginFilter</filter-class>
    <init-param>
      <param-name>charSet</param-name>
      <param-value>UTF-8</param-value>
    </init-param>
  </filter>
  <filter-mapping>
    <filter-name>Login</filter-name>
    <url-pattern>/*</url-pattern>
  </filter-mapping>


注意其过滤的URL为“/*”,表示当前的request请求。

为了使设置生效,重起tomcat。 

中文乱码

猜你喜欢

转载自blog.csdn.net/qq_37922457/article/details/80980758
今日推荐