要获取Java某类的当前路径,通过调用class.getResource 取得中文路径,返回结果如下:
D:/%e5%b7%a5%e4%bd%9c/%e7%bd%91%e7%bb%9c%e6%8e%a5%e5%85%a5%e6%8e%a7%e5%88%b6/
注:中文路径为D:/工作/网络接入控制/
%e5是URL对中文的16进制编码,结果在new File()的时候,exist始终为false,导致DOM4j没法获取XML文件。
现通过使用:URLDecoder.decode将16再转回中文,能正常读取文件
URLDecoder.decode("/%e5%b7%a5%e4%bd%9c/","UTF-8");
类:URLDecoder
方法摘要 | |
---|---|
static String | decode(String s) 已过时。 结果字符串可能因平台默认编码不同而不同。因此,改用 decode(String,String) 方法指定编码。 |
static String | decode(String s, String enc) 使用指定的编码机制对 application/x-www-form-urlencoded 字符串解码。 |
类:URLEncoder
方法摘要 | |
---|---|
static String | encode(String s) 已过时。 结果字符串可能因平台默认编码不同而不同。因此,改用 encode(String,String) 方法指定编码。 |
static String | encode(String s, String enc) 使用指定的编码机制将字符串转换为 application/x-www-form-urlencoded 格式。 |