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)静态方法,它可以将看上去是乱码的特殊字符串转换成普通字符串
实例
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);
}
}
}
运行结果
进行处理:%E7%A7%83%E5%A4%B4%E7%A8%8B%E5%BA%8F%E7%8C%BF
解码:秃头程序猿
这里使用的是UTF-8的编码方式,也可以使用其他的编码方式。
URLDecoder & URLEncoder的编码和解码规则
编码规则:
- 字母、数字和字符, “a” 到 “z”、”A” 到 “Z” 和 “0” 到 “9” 保持不变
- 特殊字符 “.”、”-“、”*” 和 “_” 保持不变
- 空格字符 ” ” 转换为一个加号 “+”
- 其他字符,通过相应的编码机制转换成一个或多个字节
解码规则刚好是反过来的。
实例
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);
}
}
}
运行结果
进行处理:aA2.-_*+%40%21
“+”前面的都没有改变,对于“@”、“!”分别编码成了%40、%21,其中%后面的是16进制,每3个字符表示一个字节,如%40表示一个字节。