文件路径折腾了好久了,参考了很多朋友的方法
目前在实施中还是用的这个方式
结果发现地址被URL类给编码了,空格都变成%20
[color=darkred]D:/Program%20Files/Apache%20Software%20Foundation/Tomcat%206.0/webapps/xml1/WEB-INF/classes/[/color]如果有汉字的话 汉字应该也会被编码(没有测试)
这就成了路径错误异常了..
API中对此的解释为:
[quote]
URL 类自身并不根据 RFC2396 中定义的转义机制编码或解码任何 URL 部分。由调用方对任何需要在调用 URL 前进行转义的字段进行编码,并对从 URL 返回的任何经过转义的字段进行解码。进一步而言,由于 URL 不懂 URL 转义,所以它不会识别同一 URL 的对等编码和解码形式。
例如,对于这两个 URL:
http://foo.com/hello world/ 和 http://foo.com/hello%20world
将被视为互不相等。
也可以使用 URLEncoder 和 URLDecoder 类,但是只适用于 HTML 形式的编码,它与RFC2396 中定义的编码机制不同。
对于URL和RUI的简单说明
URI 是统一资源标识符,而 URL 是统一资源定位符。因此,笼统地说,每个 URL 都是 URI,但不一定每个 URI 都是 URL。
[/quote]
参考API中URI
使用URI进行解码测试
倒是可以得到正确的输出
[color=darkred]D:/Program Files/Apache Software Foundation/Tomcat 6.0/webapps...[/color]
如果有更好方法,欢迎指出
目前在实施中还是用的这个方式
URL base = PropertiesReader.class.getResource("/");
String filePath = base.getFile()+"../proxool.xml";
结果发现地址被URL类给编码了,空格都变成%20
[color=darkred]D:/Program%20Files/Apache%20Software%20Foundation/Tomcat%206.0/webapps/xml1/WEB-INF/classes/[/color]如果有汉字的话 汉字应该也会被编码(没有测试)
这就成了路径错误异常了..
API中对此的解释为:
[quote]
URL 类自身并不根据 RFC2396 中定义的转义机制编码或解码任何 URL 部分。由调用方对任何需要在调用 URL 前进行转义的字段进行编码,并对从 URL 返回的任何经过转义的字段进行解码。进一步而言,由于 URL 不懂 URL 转义,所以它不会识别同一 URL 的对等编码和解码形式。
例如,对于这两个 URL:
http://foo.com/hello world/ 和 http://foo.com/hello%20world
将被视为互不相等。
也可以使用 URLEncoder 和 URLDecoder 类,但是只适用于 HTML 形式的编码,它与RFC2396 中定义的编码机制不同。
对于URL和RUI的简单说明
URI 是统一资源标识符,而 URL 是统一资源定位符。因此,笼统地说,每个 URL 都是 URI,但不一定每个 URI 都是 URL。
[/quote]
参考API中URI
使用URI进行解码测试
URL base = PropertiesReader.class.getResource("/");
String filePath = base.getFile()+"../proxool.xml";
try {
URI u = new URI(filePath);
System.out.println(u.getPath());
System.out.println(base.getPath());
} catch (URISyntaxException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
倒是可以得到正确的输出
[color=darkred]D:/Program Files/Apache Software Foundation/Tomcat 6.0/webapps...[/color]
如果有更好方法,欢迎指出