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
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值