`
jiayanjujyj
  • 浏览: 197249 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

处理URL传递中文乱码问题(续)

阅读更多

为了处理中文乱码部分能够在整个 WEB 系统中都能够使用到,所以将中文乱码处理写成了一个 Filter( 过滤器 ) ,并在 web.xml 中配置所有的请求都将经过这个 Filter 进行过滤。 Filter 部分的代码如下:

 

public class ProFilter implements Filter

{

   

    protected FilterConfig filterConfig ;

    /**

      * 初始化

      */

    public void init(FilterConfig filterConfig) throws ServletException

    {

       this . filterConfig =filterConfig;

    }

   

    private String toUTF(String inStr) throws UnsupportedEncodingException

    {

       String outStr = "" ;

       if (inStr != null )

       {

           //outStr=java.net.URLDecoder.decode(inStr);// 不用 decode , 到这的时候就已经自动 decode 过了

           // 将字符串转为 UTF-8 编码形式

           outStr = new String(inStr.getBytes( "iso-8859-1" ), "UTF-8" );        

       }

       return outStr;

    }  

 

    /**

      * 中文乱码过滤处理

      */

    public void doFilter(ServletRequest svlrequest, ServletResponse svlresponse,

           FilterChain chain) throws IOException, ServletException

    {

       HttpServletRequest request=(HttpServletRequest)svlrequest;

       HttpServletResponse response=(HttpServletResponse)svlresponse;

      

       String method = request.getMethod();

       //1. post 方式提交的请求 , 直接设置编码为 UTF-8

       if (method.equalsIgnoreCase( "post" ))

       {

           try

           {

              request.setCharacterEncoding( "UTF-8" );

           } catch (UnsupportedEncodingException e)

           {

              e.printStackTrace();

           }

       }

       //2. get 方式提交的请求

       else

       {

           // 取出客户提交的参数集

           Enumeration<String> paramNames = request.getParameterNames();

           // 遍历参数集取出每个参数的名称及值

           while (paramNames.hasMoreElements())

           {

              String name = paramNames.nextElement(); // 取出参数名称

              String values[] = request.getParameterValues(name); // 根据参数名称取出其值

              // 如果参数值集不为空

              if (values != null )

              {

                  // 如果参数值集中只有一个值

                  if (values. length == 1)

                  {

                     try

                     {

                         // 调用 toUTF(values[0]) 函数 ,(values[0] 即第一个参数值 ) 方法转换参数值的字元编码                         

                         String vlustr=toUTF(values[0]);

                         // 并将该值以属性的形式藏在 request

                         request.setAttribute(name, vlustr);

                     } catch (UnsupportedEncodingException e)

                     {

                         e.printStackTrace();

                     }

                  }

                  // 如果参数值集中有多个值

                  else

                  {

                     // 遍历参数值集

                     for ( int i=0;i<values. length ;i++)

                     {

                         try

                         {

                            // 回圈依次将每个值调用 toUTF(values[i]) 方法转换参数值的字元编码

                            String vlustr=toUTF(values[i]);

                            values[i] = vlustr;

                         } catch (UnsupportedEncodingException e)

                         {

                            e.printStackTrace();

                         }

                     }

                     // 将该值以属性的形式藏在 request

                     request.setAttribute(name, values);

                  }

              }

           }

 

       }

        // 设置响应方式和支持中文的字元集

       response.setContentType( "text/html;charset=UTF-8" ); 

 

       // 继续执行下一个 filter, 无一下个 filter 则执行请求

       chain.doFilter(request, response);

    }

   

    /**

      * 销毁方法

      */

    public void destroy()

    {

      

    }

}  

过滤器部分,可用来处理页面提交的 post get 方法产生的中文乱码问题。

Post 方式提交的数据( form 表单中提交的数据)只需要进行请求字符编码设置 request.setCharacterEncoding( "UTF-8" ); 和响应设置 response.setContentType( "text/html;charset=UTF-8" ); 设置就可以了。

Get 方式提交的数据会包含在 url 中,(如: leavesp?work= 部门主管审批),则需要取出参数名: Enumeration<String> paramNames = request.getParameterNames(); (如: work )和取出参数值: String values[] = request.getParameterValues(name);( 如:部门主管审批 ), 然后再将参数值进行编码转换: outStr = new String(inStr.getBytes( "iso-8859-1" ), "UTF-8" );

 

过滤器写好这后就需要到 web.xml < web-app > </ web-app > 之间进行配置了, web.xml 中配置如下:

<!-- 配置过滤器 -->

    < filter >

       < description > 处理中文乱码过滤器 </ description >

       < filter-name > ProFilter </ filter-name >

       < filter-class > com.util.filters.ProFilter </ filter-class >

    </ filter >

    < filter-mapping >

       < filter-name > ProFilter </ filter-name >

       < url-pattern > * </ url-pattern ><!-- 过滤所有请求,注: tomcat5 请用 /* -->

    </ filter-mapping >

 

这样配置之后只要页面有任何请求都会通过 ProFilter 进行中文处理了,就不会再发生中文乱码问题了。

 

那一串通过 get 传递过来的中文处理过程如下:

1.        jsp 页面的 JavaScript 里面进行编码处理:

url=encodeURI(‘ leavesp?work= 部门主管审批 ’)

编码后结果: url= leavesp?work=%E9%83%A8%E9%97%A8%E4%B8%BB%E7%AE%A1%E5%AE%A1%E6%89%B9

2.        因为在 web.xml 过滤器配置为 < url-pattern > * </ url-pattern > 所以所有请求将会通过过滤器进行处理,此过滤器处理过程如下:

2.1 获得参数名集合:

Enumeration<String> paramNames = request.getParameterNames();

String name = paramNames.nextElement();

2.1 结果中有 name=’work’ ;一值。

 

2.2 通过参数名获得参数值:

String values[] = request.getParameterValues(name);

work 的值只有一个所以 2.2 的结果为: values[0]=’ é ƒ¨é—¨ä¸»ç®¡å®¡æ‰¹’;( 此处得到的是字符串:“部门主管审批”的 iso-8859-1 编码格式字符 )

 

2.3 获得字符串的 UTF-8 编码格式字符:

outStr = new String(inStr.getBytes( "iso-8859-1" ), "UTF-8" );

2.3 中获得的结果为 outStr= “部门主管审批” .

至此中文已经正常了。

 

不过过滤器还没处理结束,还得将参数名对应的值 ( 已经处理的值 ) 再重新藏到请求中去。

2.4 将参数名对应结果藏入请求中:

request.setAttribute(name, outStr );

通过 2.4 处理后,请求中的 work 的值就变成了:部门主管审批

 

2.5 继续执行下一个 filter, 无一下个 filter 则执行请求

chain.doFilter(request, response);

3.        通过过滤器之后,就可以进入请求中对应 leavesp servlet 了( servlet 就不做说明了),此时在 servlet 中通过 String work=request.getParameter(“work”); 就可以获得 url 中传递过来的中文参数值了,结果为 work=” 部门主管审批

     

分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics