Java中URLDecoder和URLEncode的简单使用

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表示一个字节。