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

U2FsdGVkX18RISOlHmym6s2vo5XGW6ULNySsPz7vCQXsiii+QgRfQYAoD5LTFpvx
Sp4CjU/lza1zT+9X4z9sRqgVnFl0gYSTgcXgmpYJXBQtxcb6ItsjMM9nBwskDjmN
DDvxq45F730HrHk3J4cm0htnKbvVNd4NYLEPaLEDyvQHP2oCVbquqLmbctzpOxt+
fpXo7IxcbCZS+0s3XsRVZ/+1uLpFYdLo6/I3Ys+jJlWE8xrd1mF7Lz2SirmQkcnU
VdQkT7dnOk0xbsVroCh4bHrYWwgGQdVgV7pzOB6jREKR83pFiVzAf76IYJAjItmq
kc0Zywnx4mrB0SDr/0gbnccu8cSSIiPqznPF71HkpyxM6SVFJU4Ek4xT1Q/j9JOl
JY8hikAngTWMPjHZ7q9LBITViP8gSPRuGLqWbKUYd5lXQkK8fuK+Nmj/9/hCiL3k
qUuj01zKldsun9NpC5Iazr2u7dGwfnhR6mYbdlXiuthUHEN/3rAn3+cKUI1LHHgh
6mOFoZFAqKGfDICcovDsZRJR9frGF6dcfhGPbxXJi1P04wtLZz6+hYmH6wC/csW+
f/fxdwGR5vykwDQAO70HMFHtRrJF487oR4DR6i3xocmBz40A9VOKCVl6S1f7cS/e
UsCF52kVotXk8Uw6jyUM+BjTT3MVfCgK6vClmQ2ScfAYu5vkMP2ULGrP+oO4xlge
yTyTRG9ld9NVvN1ysC4+w4ubrSepX01p9Bzojy932SGuokWofcHhaphiO2HFbysa
Bs58b4/8KKNww4BR3coz+G13bnaJu1hK0KIwWHlAyliVZRvxBHh9AXLHd/M0Wtql
idM5SeDx7yAvcuprBMbBgjwEO8b23kiASaUS6GzS3CwcIXDK4FJfAusQugoykf2y
PQK68QnJYoN3mLOUeLScwdkIQ+OOzlgq/DsIk2HKG8X6ke5wCBEE6YRv1xVBoJ6B
ByNRA6A2pc8hlupI2rDpvGeAypSdWyWTIShJgYtpN+kaF8jUj/oSqIxkBlaunZ4q
8Tu3dGzD+wXzjrPOPv1XXhZ6w3oovXSifLJXLAjADOUc5fk4a2TbqZr43EQcbnD0
r8c+/F6ss6f4er9Sci1XaRo5f4L4SmEfqTFxhZdGS5k7QjcrExpLpX3MNp9ogWhg
dSnM3VYs0P27earo7oQBn7YQPqbVLmmf4z+SPTU1iWUqjBAP8VCE8kWc4HvtqfNt
HqrI+Qv8DLMRQpkofYSHZSngw/w8nyGPJMxfv3qB7mVfDKMmMJWU+xYOGJUgvp2+
D30e2ETpWG7SCsTGRhMvgFVnpdhH/AXQ2Qq+ml8gtvd5iB1SpPwWQvGaB/W2hdiA
Ws5JKLP1e/U0IOirwqrtg0Wvl/igYpOwMw8xNyNTDmjK+5V4M8Eci5JIu7scr1uu
0os6G1JYctIyuvH35JaEnIbgdWlF/vi6nz9BCO1J2Eh4u8XHqMr7YgeqESs5ZY9a
b+vxhyLY6WyIwr5qrKLp8j72pgR2JcZzCjg67aP/bV/hDBN9hDoxL5AKBtfIGLx0
UCvxqwlzV0VL6dQqFFWpf91N3pVHCQwvkqOJOZi4vFHoyjZtJtPD3hNyn0Jappqx
+YsWEJMq7RbhYdLMeNTPeXKACKtaD8B5T9VRixNOVw/OqSC5PuXJLBo3Wa1eLQKf
8pwmL4b4FMiMLlN+YsbaLWxhm3eGiQBhVAzJf91LaGGeHqahsHlfh6fVUkfHqtHS
XHaZmYT/WlRpMKZVy2hNqXDJjkdf5e5h+iu2Jj5MEYmykDA6JKsod+Pqtox5vSXj
wcYRNwS9oGxKWj1mzzMskKsar7tplcnNKGZB6zuFxz/Xs8nT6C4t7pyG6Bae5wR5
4TUGTu5c8lwta8uEZKllx2DhNj0PkhQHcRe+hUY1UQCML8jPXCcdklp2/XfG3s2r
wnAotL2N3CH+y8W0VJxFoHCq2iYZ0+P3cC+X+bVn56HLzayaZ1XJ68YlM7e5Q8Vr
vyit08FBYAAgKa24yXY7GSuGuhbDKvylJfW7Pmc46aahkk9676uIi1/Nei8PoFnQ
S+/bIAMlxkHG/ZsIuMbX0D4969aKw4tu7vsWkqX81haGWdVIQieKbwbYP4Ipxg35
BTGf/3a/8JjazGqz+D8PfMGDkEXlCZXFe3PQP7aCK3wS0oAjsCgCWg1Ns6VjvvJ6
pIRSJdyTXIrdka9zKXGYGjkmgSHe2XKhVGh+tWgyEaUN44ViDbYvVP2JU7fVLLRo
HoFyvaSlxEu6L3ktE7nazSnZ5HTugXXVK3V2sQTifyqOLkG23mwHg7+FaHCfo5Ot
lfhV0EWhJ+yyXYSVbaTOodDpoYJ9JaP4Tdpv0ffj9uQ5DxPFGRg86V2taICC1aU5
ePJis5VNejr0q7h4SGJBaXzerOQJgLYAUyvpWptg0nRLtHdLRcOtn99ScGznAcKj
EHMmAafWuE+sup+nkEzf20q/ncOBJ1SX/cOk/rgyhemP+SdARFqzbOyaBZdugOF4
tXLt4cCDEOpqnhbAjLicG2RAcl8TP/F0wlDLnW87bk33tip1wDYSJzXiz7FwydYC
+6NaEHPlLz0shLPoLUG/sqEY6VuocpRks3wSoFjJlU6NwuIpHGj4t9UDDkHmY6hA
pyuJ2YNguh53zGIoWAJupLqObuqd2NtTY1VtK8hbBCqWKjN/WhTLNKTMEdEQdb3q
qJrb7ZR0IdiOTkn8cK4lRkHJtAD3hD3qklYB5h//5KpnNS7KT46CKThBUF1iavKW
X8AzPpnjrY615hH3eUEPSPORk1Im/s6KKyspruqqLbit8vMIPezveKqtikFJmQMJ
6U56pzzPgJETmAWmFrMVQaBxuKgJ3k2/xpkIwWXxMlVwd8ASbeeCvjCdlx3ER1kw
mqqyPmEggjYpBqnflmJo/qJBG/KOPuwM+AWRkW6DPtX+QAaI/lI59gT7Lf+k8lPF
p8fDpILkIBu8J5mP3ogLnj3DXLDlRfYr/YFcgqgI2nqu24R8WqGBsNro1dtgjkEl
3q/jIoutC6Srfw7WOSj2Gzyde+Bv9UzheMAQUPkD6mdBPGkBZ8x+5ANeu/oz63JI
xQmizhN6uB+quJBrUKI51bbrpi02Eqlk2j3s+dGHq8FRsMhF+PS0IM65y+oWgW3i
MEK85C1JgWKoaVSFBuaAnc0FWFllmp7I/TIuBLP2zZ3o/NbH1UDLYcq+IbBcZlml
a8PIIbm7f3DcHRZp5LBkWxXYWaiFGR5lt/xiK3BDyt23iTT+7Dadz+9M9oIed3za
1v0U9vK3N2x9VsTptig1uyInZWy6fMvOzN9Pv8QVhwww8qd+gBTrfWv8aVgj1f2N
t6UOcyHjQCdICVudgQ4lsFYrGopq17AL/baV4U0PBxdu67i/fKA9jHV43f/DnytI
XkK8DKqHRervfKSSpSCVguxMSSARE1uynkcBTskCDA5WMq7ust4HS1IIdqIsgoe0
NgGhcWXLjIjL4YdVFzqWQMX4Ys+tqT78wKawjeGqYuUJcoIUbsKHowIZT7y4ojl/
fjtiquVzH2fNmgI4fMZnjkq8LCyfyybcD5rexO6r262ww1wOXmkO0c8OCLmONbe7
gE5lT2Va773Rik37YZWdASqdmMxjXMIIrZJYx/KSvwVu+R8vbRw32GK124Cr5Y+Z
517fDmhd3fI9rhN5J3JU5/Qg6cyaWCK6E22j7OiDXwAtctPqCYd8sAf2AcDscEw+
RT6mr3hn5lt9okWjzhdfjK8yP+Fxqa0OJ5QB5mijgXoYFVWGeSaOZU6mR+AfKBkp
dxN6vtDdMeir2wlYtj3yG0xalR0HCwrkY1HvcEHXzDwS5BYQ7DzbJDScccjzNU+d
po0JTBxrXT2EpBG2JNE5DQ==

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值