解决乱码问题总结





在进行struts开发的过程中,总也是出现很多的乱码问题 ,但归根到底,也只是以下三种情况:

㈠页面显示中文乱码

㈡传递参数中文乱码

㈢数据库中的乱码



下面就这三中情况介绍怎么在具体项目中处理这些乱码问题。而对于整体的处理思想,是要统一编码为: UTF-8.(myeclipse6支持的struts1.3为准)

㈠页面显示中文乱码

  
对于在页面中显示出现乱码,这个问题比较简单,便是检查你的JSP文件里是不是出现了中文要处理,因为JSP默认的编码格式为“ISO-8859-1”,当JSP中出现要处理的中文时,其显示就出现乱码了,这种情况一般出现在手写JSP,或修改时。因为在myeclipse6.0中,如果出现了编码错误时,程序不会让你保存,而是会提示你注意编码,这点很好。具体的修改办法是把

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

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

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


㈡传递参数中文乱码

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

 

publicActionForwardexecute(ActionMapping mapping,ActionForm form, HttpServletRequestrequest,  

            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文件,在修改端口的标签后面加一行代码,如下:

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

 <Connector port="8080"protocol="HTTP/1.1"

              connectionTimeout="20000"

              redirectPort="8443" URIEncoding="UTF-8"/>


编写过滤器Filter

publicclassCharacterEncodingFilterimplementsFilter{  

     @Override 

      publicvoiddestroy()...{  

      }  

        

     @Override 

     publicvoiddoFilter(ServletRequestrequest, ServletResponse response, FilterChain chain) throwsIOException,ServletException  {  

         request.setCharacterEncoding("utf-8");  

          chain.doFilter(request, response);  

      }  

        

     @Override 

     publicvoidinit(FilterConfigarg0) throwsServletException...{  

      }  

}    

import java.io.IOException;

 

import javax.servlet.Filter;

importjavax.servlet.FilterChain;

importjavax.servlet.FilterConfig;

importjavax.servlet.ServletException;

importjavax.servlet.ServletRequest;

import javax.servlet.ServletResponse;

 

public classCharacterEncodingFilter implements Filter ...{

 

   @Override

   public void destroy() ...{

   }

 

   @Override

   public void doFilter(ServletRequestrequest, ServletResponse response, FilterChain chain) throws IOException,ServletException  {

   request.setCharacterEncoding("utf-8");

   chain.doFilter(request, response);

   }

 

   @Override

   public void init(FilterConfig arg0) throwsServletException ...{

   }

 

}

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

修改web.xml文件

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

<filter> 

   <filter-name>characterEncoding</filter-name> 

   <filter-class>com.v512.example.CharacterEncodingFilter</filter-class> 

   </filter> 

<filter-mapping> 

   <filter-name>characterEncoding</filter-name> 

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

</filter-mapping>  

   

 <filter>

 <filter-name>characterEncoding</filter-name>

 <filter-class>com.v512.example.CharacterEncodingFilter</filter-class>

 </filter>

 <filter-mapping>

 <filter-name>characterEncoding</filter-name>

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

 </filte注意其过滤的URL“/*”,表示当前的request请求。为了使设置生效,重起tomcat


㈢数据库中的乱码问题的解决

     第一:如果是mysql数据库,

       在  mysql  控制台 里面输入 这个命令 看下是什么样的show variables like 'character%';不是utf-8或GB2312、GBK的话输入下面命令:
      SET character_set_client = utf8; 
      SET character_set_connection = utf8; 
      SET character_set_database = utf8; 
      SET character_set_results = utf8; 
      SET character_set_server = utf8

      在数据库驱动连接上面添加useUnicode=true&amp;characterEncoding=utf-8

     第一:在创建数据裤的时候申明编码UTF-8;

     第二:在创建表饿时候申明编码UTF-8;






















  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值