url和uri区别

在这里插入图片描述

这两天在写代码的时候,由于涉及到资源的位置,因此,需要在Java Bean中定义一些字段,用来表示资源的位置,比如:imgUrl,logoUri等等。但是,每次定义的时候,心里都很纠结,是该用imgUrl还是imgUri呢?

同样的,另外一个问题:String HttpServletRequest.getRequestURI();和StringBuffer HttpServletRequest.getRequestURL();返回的内容有何不同?为什么会如此?

带着这些问题到网上去搜了下,没发现让自己看了明白的解释,于是,想到了Java类库里有两个对应的类java.net.URI和java.net.URL,终于,在这两个类里的javadoc里找到了答案。

URIs, URLs, and URNs

首先,URI,是uniform resource identifier,统一资源标识符,用来唯一的标识一个资源。而URL是uniform resource locator,统一资源定位器,它是一种具体的URI,即URL可以用来标识一个资源,而且还指明了如何locate这个资源。而URN,uniform resource name,统一资源命名,是通过名字来标识资源,比如mailto:java-net@java.sun.com。也就是说,URI是以一种抽象的,高层次概念定义统一资源标识,而URL和URN则是具体的资源标识的方式。URL和URN都是一种URI。

在Java的URI中,一个URI实例可以代表绝对的,也可以是相对的,只要它符合URI的语法规则。而URL类则不仅符合语义,还包含了定位该资源的信息,因此它不能是相对的,schema必须被指定。

ok,现在回答文章开头提出的问题,到底是imgUrl好呢,还是imgUri好?显然,如果说imgUri是肯定没问题的,因为即使它实际上是url,那它也是uri的一种。那么用imgUrl有没有问题呢?此时则要看它的可能取值,如果是绝对路径,能够定位的,那么用imgUrl是没问题的,而如果是相对路径,那还是不要用ImgUrl的好。总之,用imgUri是肯定没问题的,而用imgUrl则要视实际情况而定。

第二个,从HttpServletRequest的javadoc中可以看出,getRequestURI返回一个String,“the part of this request’s URL from the protocol name up to the query string in the first line of the HTTP request”,比如“POST /some/path.html?a=b HTTP/1.1”,则返回的值为”/some/path.html”。现在可以明白为什么是getRequestURI而不是getRequestURL了,因为此处返回的是相对的路径。而getRequestURL返回一个StringBuffer,“The returned URL contains a protocol, server name, port number, and server path, but it does not include query string parameters.”,完整的请求资源路径,不包括querystring。

总结一下:URL是一种具体的URI,它不仅唯一标识资源,而且还提供了定位该资源的信息。URI是一种语义上的抽象概念,可以是绝对的,也可以是相对的,而URL则必须提供足够的信息来定位,所以,是绝对的,而通常说的relative URL,则是针对另一个absolute URL,本质上还是绝对的。

注:这里的绝对(absolute)是指包含scheme,而相对(relative)则不包含scheme。

URI抽象结构 [scheme:]scheme-specific-part[#fragment]

[scheme:][//authority][path][?query][#fragment]

authority为[user-info@]host[:port]

参考资料:

http://docs.oracle.com/javase/1.5.0/docs/api/java/net/URI.html

http://en.wikipedia.org/wiki/Uniform_Resource_Identifier

http://docs.oracle.com/javaee/5/api/javax/servlet/http/HttpServletRequest.html

ps:

java.net.URL类不提供对标准RFC2396规定的特殊字符的转义,因此需要调用者自己对URL各组成部分进行encode。而java.net.URI则会提供转义功能。因此The recommended way to manage the encoding and decoding of URLs is to use java.net.URI. 可以使用URI.toURL()和URL.toURI()方法来对两个类型的对象互相转换。对于HTML FORM的url encode/decode可以使用java.net.URLEncoder和java.net.URLDecoder来完成,但是对URL对象不适用。

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

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值