URLEncode编码和URLDecode解码

时间:2023-03-09 21:20:41
URLEncode编码和URLDecode解码
 String  text1 = java.net.URLEncoder.encode("中国" ,"utf-8" );
String text2 = java.net.URLDecoder.decode(text1,"utf-8");

URLEncode编码和URLDecode解码

(1).URLEncoder
需要注意:这个方法编码了符号,“\” ,“&”,“=”,和“:”,并把空格(“ ”)转换成了(+)。它不会尝试着去规定在一个URL中这些字符怎样被使用。由此,你不得不分块编码你的URL,而不是把整个URL一次传给这个方法。

  例如,假设你想编码这个string:

  pg=q&kl=XX&stype=stext&q=+"Java+I/O"&search.x=38&search.y=3

  这段代码对其进行编码:  

 String query = java.net.URLEncoder.encode( "pg=q&kl=XX&stype=stext&q=+"Java+I/O"&search.x=38&search.y=3");

 System.out.println(query);

  不幸的是,得到的输出是:

  pg%3Dq%26kl%3DXX%26stype%3Dstext%26q%3D%2B%22Java%2BI%2FO%22%26search.x%3D38%26search.y%3D3

  出现这个问题就是方法URLEncoder.encode( ) 在进行盲目地编码。它不能区分在URL或者查询string中被用到的特殊字符(像前面string中的“=”,和“&”)和确实需要被编码的字符。所以URL需要一次只编码一块。

  例如正确的拼接方法:
  
 private static String _MakeURL(String p_url, Map<String, Object> params) throws UnsupportedEncodingException {
StringBuilder url = new StringBuilder(p_url);
// Strng.indexOf(substring) //搜索String中的substring,默认从0位开始; if(url.indexOf( "?")<0)
url.append( '?'); for(String name : params.keySet()){
url.append( '&');
url.append(name);
url.append( '=');
//url.append(String.valueOf(params.get(name)));
//做URLEncoder处理
url.append(URLEncoder. encode(String.valueOf (params.get(name)), "UTF-8"));
} return url.toString().replace( "?&", "?");
}
(2).URLDecoder
  注意:由于这个方法没有触及到非转义字符,所以你可以把整个URL作为参数传给该方法<如下面的qerry>。不用像之前那样分块进行,依然可以得到你想要的正确的解码结果。例如:
  
   String input = "http://www.altavista.com/cgi-bin/"+"qerry?pg=q&kl=XX&stype=stext&q=%2B%22Java+I%2FO%22&search.x=38&search.y=3";  
    try {  
       String output = java.net.URLDecoder.decode(input, "UTF-8");  
       System.out.println(output); 
     }
综上所述:UrlEncoder一次只能编码一块,然后拼接起来,成为一个url ; 而UrlDecoder可以一次性解码整个链接。