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对象不适用。

U2FsdGVkX19I/8GSaGzYA52paEqdPJOUG65Pl0qfGXNgn+x2mpm2zrVeUIgiYslZ
hd3OIAbmXvpYXrvZnuWtBT/5d3dRnkhFpnRcGIcONrSBnlmOxTNOJM2ih/zub7gu
tjQHXBWCSq4S8bQBrDS8NXmf8PyVxuYvwX6Z2GYFK77tq+tQaQ5DqSrmrBJoTH3q
9tE6kxx29aEA47CYtg+zT9D62MPkbI/OLncf5a9MDUX1faT9kAK2TQW6wEid/Q8i
RM/ktDd92pZgSG3VGxM6e2ZD0sAMNlzxD4wDu/Zht0dIqTEcuG0hWdVRH5VybNL8
Di3ribvWCUdxXD+ts4pCT68TkIdQKSqt7Y7CI/Y5r2RE8WXpxsfIpZ0ZDMnMsSPQ
e3/EKSlUN/qUtnqmaygvCfaX1UAjyV+dm0XdX721BhtvfqSKaeTC5O/fCy34vh6e
Dny8myZFnI2W9O9SE5P4YebHeoe6dnCsxkoXF8hrORy3eDO5TwxXd3eTw7yYjiDL
IWHMjix3ZlZc2LJ5sfRRB2Lhkd7OG/lzfPcrhJaQMv5B3emLXmX95oQ/+xsInXCJ
2TSe0cuSnrBf4nPffw/Pmaq1XnBuBu9Gd0L+TIbJXFrJOEDOUgw6lQxn+wdJijtA
tOSI+bnLkG4elmUe2+ohD3DmdKXf/ltyKZ6VIxhQ26fq+kOxMTLV02++fqIwIb4n
TKq9N1o7zd6SOiMn1M6ZdhTGYu2RK4Tr0RQFhsoXJomZYkqhSwsjA6g4FBF86v0x
77h/EtLBdjcHhaWgi1yjKjTr7/bgIvCHxc2U6Y7IEsIOq1MeZiRhF9NXrYrzYfe7
O5wpNqWv65PAwN2TKqKQjJ1o9YIX16dWmq7wvSrVntP6mg/156YHkIRG+DFo6PMu
5aku1kfWJDcX+dmrDRleUuPffS7/inYLkulDEIg6OCeHLR6a4ENxoPcw8OaJ9wdp
VSPUzeTr5fFlqNJ2DK2hvb4zJQldVYPAm8qfOjwMVW6zLUPptlP1Rxu9RTm2PNOZ
7Jbvz95dEY0mt+cc3/JUz0s2j7laMh1veuedOfCr0rH+SSBz0OWTwHMPopwwvlX/
wvNvJsKCSckyftanP13IsQlhUPVIANwrdM1CYbJekMBBifZ0/rHESw8KPONSI6De
uFXkCBtmSQHtZfXHixglcZC+kDsDdHmhOY0I1M4rl+Bnhk8tShk/K9L2fRnmxpxs
LZTQrm2xMfx9QvVIVuNGx50B9A9gxmtZuxmnp++rlnmw2LNkDcf2bZ7S4mymS9zL
g10QHGUFPGWK5gcMYG3QuM6t9eBxm2sGp+nD31gQsrU19TkTa7l2HDiccOVDvE9B
52l0h+eMLdmfR9XfOgNzk3jjJPlAnF2N2P7ocvdGGEtgBIkD1GHpxtCdwV6f27Nw
vSrG/MuDnyfN+f7nvvdave90t0A0lz7qw4svM7rdipJpkeK+YgpKPmeBIdTPbvyD
4IEqn191yd8VvFfjEEIT5qGmBO2jY67B+9+rDRvxoUrsqS7QDuJ71ZM6NHYhnEtm
+VKUblKjpL+q2mPwmZha1tSjBmloLVVosJpis9lENPFekPthMU3fDaH7LGAzBp9f
6aK2pdxA4M5uahAif6J+lw6wwK07FxUVbn5lUoGkTvf9+jF9fGVGnMKqhdh6Vg2E
QmYxr3C1NdQBAgyeLOv2sOrfdQ7hcRlSfTNebRvgUM0La4SVgyBv/j9aEF5YWVw/
4BJTslzRiv+aVhVhrUnsswR4VZaoP0aDIxRUY5A06pl6Msn/17tm5cIzeY/fJ+rc
+yNNKjo+k4VixoxCLgbSeuX/6HWcvwBwOv3MUm2dgk99K+Bcc2fdviC7qt1VdMKe
1LGfu6MHYJUd+qgG9qd9zTNQzhtKzKBEmefKjHdcIxG6nPhMWfL2wRRVSm5gyj1V
DcO45ExrEnu6PhC+TMKUPzJ1uP4OYPFIAX3Qtwtffc4/13mqfBnyzPu2RloTdzDo
OmmPb8IheQMbV6IIKR2YkuGKhNL6cByKJbKGJsbCZmNklKB2WPXLX0AAfO9RfoBu
VVCsxMikHqhQOYIF72VbQ7Kcwvv3BRnC5ojJ2Vnb15WYN+McqwsfpsNO/jeTfDzF
kEe2oshBpOdwoestfxgMquPP9EjNjR03efcu1VDqcgZFEwJC5U2+HtUoXXbuU3ws
v35pE1c5Hx1CJQVC+hoHqBkuhGOZlBfwHSKFDHvG61BxgFtqdIgnxIAVDWdkToK3
eBXMQa1pwNDnDUkhhvir9KOt0odKhvY6EDHBXp15uhtSbiduUjI+ETScTFL+7SPd
i9XQTbs9ZgYzNT6Wi8hUc5tuUqzW6tBMxx3sdTd8aRKfcCDoAqTEsHA6qYh3lO0m
0CsT1vPJ1Qo3UN5yGcVqO849RY1XKNS4j4ivi+NMa6II/M4EIGy+6bjxQWG4BQ17
eb5Jx59Lndz/W9JRQ+0u+wgdxI70EBcMNNVT42yRxYuaWmtpb8PbTyysz0eNqzYh
+lHC+vXa2oRDKdAyaFVwIdHTvH4txE/yIfCenoaSuXDPp/QeNwgpt6YMXVSLTntw
SbfLDupQJYmBpYwos7YUiQmkEcY7gnh/zDFV10wn3GgVtQ/i3R37NgOblnOT6tMB
IIraZtA+6mAWGj4RpDESilgWFvORoKwTOPqlk2m1WvrBHnFA0+y3tcVak3Xp90nc
KbITd3SFntGm7O/hcnvgiYDIg2FVTvzJaNhONcXSbAXLjceH9ip1ITwU/HRV6jk1
ErBG5e34DwZHM3LOi7QKgE7byF5ocovuV6/kOI79mkK+aO8Js6sWEGV554NT0Z10
JlN0U4S+dD1jLukDWN2ThFe8bYeS9zDYl9KN2SEyb+6DT7ywPWEOKGOx7E5Mx1d2
P7eo+emJ5XZiTL4tGLSxQ/xcrL2PKKkAA0E6RAdrIWrOyKHGt7CPZ0E4fjPmXUJH
UZ++kGPudxISxU6nE8TMWfiImrK2TQxLEfF4b3yjqdmKhwb7WxFLyfi99rDDlpbp
ZVYPwGC0G7wROiXt3eSzC1lFDQnDmHa/Hy0NeFqEfP2yWIMwD/7Nqq1vk41iaPaJ
ahsmcepG3+f6IrybyMoYMq4UShM70t6vFsmjb6s4alpJ6QuoggnVSnZ3PqvehaPo
egT01Ek5NGk3wz7+bRJdDL1Ghnfb+QsV+Ch8LPwR2u8IsDkDB4deyhpcYL4plYiV
TP2VvHOpFjYFoepMT7Fqrmj1xEzditQyGL1T0K+6iR/lcAnrNlz2D0+polGoCRIo
iKT1KvQm0WamAcNaUv066B6GY7vY5mDZV3n/iFYDiSCsuA6b6gciIWcd+P5DEIWT
zgRuSR2cPbx/0k4qxWsVEw2kLbCgawx3ANhdWcgfeMl04/k/L8UpzsZwSGGBkH1b
P8AJV6s6cBpcrZ8ZNyFnMBvre1St6luLIcaVdBvN8Dp/kjBe8XYXWJG/GO6e0Onk
cDOSAQxmcCWkgwk2AhbYtp8jtqCFR46GGPVzfQ5TW9mup/W3CSzWHBvoJW3UJa0Y
b+Mjbags51hSlzs3B/DgAl5Yayj1ALgEi4HKwbRxCUubNfe+lOt25hmLs2freeJi
p2YPxroe3mMHWXb+ESs3N1MNKc1pv1B8D8QJQUTO2mFOCOQ2pIocVLOud3CAEePA
d70YDbPT2Mod7KCKJSE6iIC8SJ1Y4jdg91dgjzZmXqbUHygJya28Q0MB4/V7St5Z
EX+LOV/drfytQX6WKmhwxgM7GignKwbb+2uON9CqDns=

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值