URL和URI的区别论谈



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

同样的,另外一个问题: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

转载来源:http://www.cnblogs.com/gaojing/archive/2012/02/04/2413626.html

<think>好的,用户问的是URLURI区别,我需要先回忆这两个概念的定义用途。URI的全称是统一资源标识符,而URL是统一资源定位符。首先得确认它们的定义,然后找出区别。 记得URI是用来标识资源的,而URL不仅标识资源,还提供了如何访问该资源的具体位置方式。比如,URL像是详细的地址,告诉你哪里找到资源,而URI可能更广泛,可能包括URLURN,URN是统一资源名称,用来标识资源但不指定位置。 然后需要组织语言,用例子说明。比如,URL的例子是https://www.example.com/page.html,而URI可以是这个URL,也可以是像urn:isbn:0451450523这样的URN。要强调URLURI的子集,所有URL都是URI,但URI不一定是URL。 要检查是否有混淆点,比如用户可能认为URIURL是同一个,需要明确它们的关系。另外,是否需要提到URN?可能有必要,因为URI包括URLURN,但用户可能没问到这个,不过为了完整解释,可以简要提及。 接下来,结构要清晰。先分别定义URIURL,然后比较它们的区别,最后用例子说明。确保使用正确的术语,避免技术错误。比如,URI的组成部分可能有scheme、path等,而URL必须包含访问方法的位置信息。 还需要考虑用户的使用场景,可能是在开发Web应用或学习网络基础知识,所以需要结合实际应用场景解释。例如,用户在浏览器输入的是URL,而某些API可能使用更一般的URI来标识资源。 最后,总结两者的关系区别,帮助用户一目了然。确保语言简洁,避免过于技术化,让不同层次的用户都能理解。</think>好的,让我们逐步理清URLURI区别: 1. **概念定义** - **URI(Uniform Resource Identifier,统一资源标识符)** - 是用于**标识**某一互联网资源的字符串 - 例如:`mailto:user@example.com`、`urn:isbn:9787115470662` - **URL(Uniform Resource Locator,统一资源定位符)** - 是用于**定位**并访问某一互联网资源的字符串 - 例如:`https://www.example.com/index.html` 2. **核心区别** $$ \text{URL} \subset \text{URI} $$ - URL属于URI的子集,所有URL都是URI,但URI不一定是URL - **URL必须包含资源访问方式**(如`http://`, `ftp://`)**具体位置** - **URI可以是抽象标识**(不包含具体访问方式) 3. **典型结构对比** ```plaintext URI通用格式: [scheme:][//authority][/path][?query][#fragment] URL必须包含: [协议://][主机名][:端口][/路径][?参数][#锚点] ``` 4. **应用场景** - URL:浏览器地址栏输入、超链接跳转 - 例:`https://www.youtube.com/watch?v=dQw4w9WgXcQ` - URI:API接口设计、XML命名空间 - 例:`spotify:album:6NMZrFdHEuZYUqFTWI5mFb` 5. **特殊类型** - **URN(统一资源名称)**:URI的一种特殊形式 - 永久标识资源,不依赖位置(例:`urn:issn:0167-6423`) - 关系式:$$ \text{URI} = \text{URL} \cup \text{URN} $$ **总结记忆表**: | 特征 | URI | URL | |-----------|--------------------------|--------------------------| | 主要功能 | 标识资源 | 定位资源 | | 是否包含位置 | 不一定 | 必须包含 | | 使用场景 | 资源标识(广义) | 资源访问(具体) | | 示例 | `tel:+1234567890` | `ftp://example.com/file` |
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值