注册 登录  
 加关注
   显示下一条  |  关闭
温馨提示!由于新浪微博认证机制调整,您的新浪微博帐号绑定已过期,请重新绑定!立即重新绑定新浪微博》  |  关闭

和申的个人主页

专注于java开发,1985wanggang

 
 
 

日志

 
 

JAVA 中URL链接中文参数乱码的处理方法  

2008-11-28 15:35:19|  分类: Java |  标签: |举报 |字号 订阅

  下载LOFTER 我的照片书  |

JAVA 中URL链接中文参数乱码的处理方法 - 和申 - 和申的个人主页

JAVA 中URL链接中文参数乱码的若干处理方法,目前整理收录如下:

方法一:

http://xxx.do?ptname=’我是中国人’

String strPtname = request.getParameter("ptname");

strPtname = new String(strPtname.getBytes("ISO-8859-1"), "UTF-8");  

方法二:

<%@ page contentType="text/html;charset=gb2312" %>

<a href="ds.jsp?url=<%=java.net.URLEncoder.encode("编码的是这里","GB2312")%>">点击这里</a>

<%

//request.setCharacterEncoding("GBK");

if(request.getParameter("url")!=null)

{

str=request.getParameter("url");

str=java.net.URLDecoder.decode(str,"GB2312");

str=new String(str.getBytes("ISO-8859-1"));

out.print(str);

}

%>

==================================

public String chinatoString(String str)

     {

      String s=str;

      try

      {

       byte tempB[]=s.getBytes("ISO-8859-1");

       s=new String(tempB);

       return s;

      }

      catch(Exception e)

      {

       return s;

      }

    }

====================================================

function URLencode(sStr)

    {

      return escape(sStr).

               replace(/+/g, ’%2B’).

                  replace(/"/g,’%22’).

                     replace(/’/g, ’%27’).

                       replace(///g,’%2F’);

    }

方法三:

如果用jstl的话,能自己写一个el的function,调用URLEncoder.encode来编码。

IE缺省对URL后面的参数是不编码发送的,不过tomat缺省是按ISO8859-1来进行URL解码,因此才会出现上述错误。好的做法是:

1、在URL参数中确保用UTF-8编码之,方法能用js函数encodeURI(),或调用自定义的el function;

2、设置server.xml中的Connector熟悉URIEncoding="UTF-8",确保解码格式和编码格式统一;

方法四:

<script>

for(var i=0;i<document.links.length;i++){

document.links[i].href=encodeURI(document.links[i].href);

}

</script>

在action中,String s=request.getParameter("s");

s=new String(s.getBytes("iso-8859-1"),"gbk");

以上方法是收聚了一些网友所讲的解决方法 。

=====================================================================================

=====================================================================================

String encodeStr = java.net.URLEncoder.encode("编码的是这里","GBK");
  System.out.println("编码后:"+encodeStr);
  String decodeStr = java.net.URLDecoder.decode(encodeStr, "GBK");
  System.out.println("解码后:"+decodeStr);  
  System.out.println("------------------------------------------");
  String enc = "编码的是这里";
  enc = new String(enc.getBytes(),"iso-8859-1");
  System.out.println("enc="+enc);
  String dec = new String(enc.getBytes("iso-8859-1"),"GBK");
  System.out.println("dec="+dec);

输出结果:

编码后:%B1%E0%C2%EB%B5%C4%CA%C7%D5%E2%C0%EF
解码后:编码的是这里
------------------------------------------
enc=±à??????????
dec=编码的是这里


 其它:tomcat中url传中文参数乱码解决

js自动补全提示(即时查询) - 和申 - 和申的个人主页 js自动补全提示(即时查询) - 和申 - 和申的个人主页 js自动补全提示(即时查询) - 和申 - 和申的个人主页js自动补全提示(即时查询) - 和申 - 和申的个人主页js自动补全提示(即时查询) - 和申 - 和申的个人主页 

  评论这张
 
阅读(4718)| 评论(0)
推荐 转载

历史上的今天

在LOFTER的更多文章

评论

<#--最新日志,群博日志--> <#--推荐日志--> <#--引用记录--> <#--博主推荐--> <#--随机阅读--> <#--首页推荐--> <#--历史上的今天--> <#--被推荐日志--> <#--上一篇,下一篇--> <#-- 热度 --> <#-- 网易新闻广告 --> <#--右边模块结构--> <#--评论模块结构--> <#--引用模块结构--> <#--博主发起的投票-->
 
 
 
 
 
 
 
 
 
 
 
 
 
 

页脚

网易公司版权所有 ©1997-2016