要获取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 格式。 |
本文介绍了在Java中如何处理含有中文字符的文件路径问题。通过使用URLDecoder类的decode方法并指定UTF-8编码,可以将经过URL编码的中文路径正确解析,确保能够正常读取文件。
1314

被折叠的 条评论
为什么被折叠?



