`
wh8766
  • 浏览: 34874 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

文件路径的转译

阅读更多
文件路径折腾了好久了,参考了很多朋友的方法
目前在实施中还是用的这个方式

URL base = PropertiesReader.class.getResource("/");
	String filePath = base.getFile()+"../proxool.xml";


结果发现地址被URL类给编码了,空格都变成%20
D:/Program%20Files/Apache%20Software%20Foundation/Tomcat%206.0/webapps/xml1/WEB-INF/classes/如果有汉字的话 汉字应该也会被编码(没有测试)
这就成了路径错误异常了..

API中对此的解释为:
引用

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。


参考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();
			}

倒是可以得到正确的输出
D:/Program Files/Apache Software Foundation/Tomcat 6.0/webapps...

如果有更好方法,欢迎指出
分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics