URLDecoder & URLEncode的简单使用
目录
-
- URLDecoder & URLEncoder的简单介绍
- URLDecoder & URLEncoder的编码和解码规则
URLDecoder & URLEncoder的简单介绍
URLDecoder类和URLEncoder类的功能是,完成普通字符串和application/x-www-form-urlencoded MIME 字符串之间的相互转换。application/x-www-form-urlencoded MIME 虽然不是普通的字符串,但是在现实应用中经常见到,例如搜索引擎网址中看似是乱码的内容,如图所示。
在编程过程中可以将普通字符串和这种特殊字符串相关转换,此功能是通过使用URLDecoder和URLEncoder类实现的。
-
URLEncoder类:包含一个encode(String s,String enc)静态方法,它可以将普通字符串转换成application/x-www-form-urlencoded MIME字符串
-
URLDecoder类:包含一个decode(String s,String enc)静态方法,它可以将看上去是乱码的特殊字符串转换成普通字符串
实例
1 2 3 4 5 6 7 8 9 10 11 12 13 14 | import java.net.*; public class Demo {<!-- --> public static void main(String[] args){<!-- --> try{<!-- --> String encodeStr = URLEncoder.encode("美国大选", "utf-8"); System.out.println("进行处理:" + encodeStr); String decodeStr = URLDecoder.decode(encodeStr, "utf-8"); System.out.println("解码:" + decodeStr); }catch(Exception e){<!-- --> System.out.println("捕获异常"+e); } } } |
运行结果
1 2 | 进行处理:%E7%BE%8E%E5%9B%BD%E5%A4%A7%E9%80%89 解码:美国大选 |
这里使用的是UTF-8的编码方式,也可以使用其他的编码方式。
URLDecoder & URLEncoder的编码和解码规则
编码规则:
- 字母、数字和字符, “a” 到 “z”、”A” 到 “Z” 和 “0” 到 “9” 保持不变
- 特殊字符 “.”、”-“、”*” 和 “_” 保持不变
- 空格字符 ” ” 转换为一个加号 “+”
- 其他字符,通过相应的编码机制转换成一个或多个字节
解码规则刚好是反过来的。
实例
1 2 3 4 5 6 7 8 9 10 11 12 | import java.net.*; public class Demo {<!-- --> public static void main(String[] args){<!-- --> try{<!-- --> String encodeStr = URLEncoder.encode("aA2.-_* @!", "utf-8"); System.out.println("进行处理:" + encodeStr); }catch(Exception e){<!-- --> System.out.println("捕获异常"+e); } } } |
运行结果
1 | 进行处理:aA2.-_*+%40%21 |
“+”前面的都没有改变,对于“@”、“!”分别编码成了%40、%21,其中%后面的是16进制,每3个字符表示一个字节,如%40表示一个字节。