2019独角兽企业重金招聘Python工程师标准>>>

这两天在写代码的时候,由于涉及到资源的位置,因此,需要在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对象不适用。

转载于:https://my.oschina.net/WinkJie/blog/3051579

URL/URI/URN的认识相关推荐

  1. URL, URI, URN 和 IRI 表示的意思

    URL, URI, URN 和 IRI 表示的意思 参考 许多人知道URI是一种类似URL的东西,但是并不是真正知道URI和URL的关系,或者URI跟其他缩略词IRI和URN之间的关系. 大多数人对U ...

  2. URL,URI,URN三者的区别和联系(统一资源定、统一资源标识符、统一资源名称)

    1.URL(统一资源定位符--Uniform Resource Locator): 指向Internet中位于某个主机上的资源,通常由四部分组成: 协议名称(常为HTTP) 页面所在主机的的DNS名或 ...

  3. JAVA基础 - URI、URL和URN的区别

    什么是URI(统一资源标识符)? "A Uniform Resource Identifier (URI) 是一个紧凑的字符串用来标识抽象或物理资源." 用于标识一个抽象或物理资源 ...

  4. URI、URL以及URN的区别

    首先,URI,是uniform resource identifier,统一资源标识符,用来唯一的标识一个资源.而URL是uniform resource locator,统一资源定位器,它是一种具体 ...

  5. URI,URL和URN有什么区别?

    人们谈论URL , URI和URN好像是不同的东西,但是用肉眼看起来都是一样的. 它们之间有什么明显区别? #1楼 这是我的简化: URN:唯一资源名称,即" what"(例如ur ...

  6. URI和URL及URN的区别

    对于URL,大家都比较熟悉,其他两个词就比较陌生了.URI.URL和URN是识别.定位和命名互联网上的资源的标准途径.1989年Tim Berners-Lee发明了互联网(World Wide Web ...

  7. 【Android】Uri和Url和URN

    最早在Android方面接触这两个概念,是学习ContentProvider的时候,当时花了很多时间,始终不能很好的理解他们的区别,顺带着ContentProvider的用法也无法理解,最近通过实现网 ...

  8. 【计算机网络】URI、URL、URN 辨析

    URI URI,即Uniform Resource Identifier,中文名为"统一资源标识符". 众所周知,每个Web服务器资源都以一个名字,用以客户端访问和获取,这个&qu ...

  9. URI,URL与URN的区别

    2017-11-13 16:51:49 URI = Universal Resource Identifier 统一资源标志符 URL = Universal Resource Locator 统一资 ...

最新文章

  1. 如何刷新JTable
  2. 黄河科技学院计算机补考好过吗,学生吐槽:重修费每学分240元不该收 黄河科技学院回应:收费合理...
  3. Mac中安装git后,终端运行git出错,提示安装Xcode
  4. react native基本调试技巧
  5. 算法设计7—哈希表1
  6. 仔细讨论 C/C++ 字节对齐问题⭐⭐
  7. JavaScript高程第十章:DOM(上)
  8. tar 备份时如何保持权限
  9. public ServiceException() { super(); } public ServiceException(String message, Throwable cause,
  10. centos7 安装MyCli MySQL 客户端
  11. [ An Ac a Day ^_^ ] CodeForces 680A Bear and Five Cards
  12. 考计算机科学考研老师问,名师答疑:计算机专业考研复习6问!
  13. windows下如何用python抓取邮件内容和附件_用python下载邮件内容
  14. Oracle+PL+SQL从入门到精通.丁士锋.清华大学出版社.2012
  15. SharePoint 2013 母版页修改后,无法添加应用程序
  16. win10解压软件哪个好(win10用哪个解压软件)
  17. Rockchip RK3588 MIPI-DSI2 详解
  18. 猴子爬树php,爬树就像猴子一样顺溜的生肖女
  19. OpenStack 2015年度总结
  20. Git error: cannot spawn ssh: No such file or directory的一个解决办法

热门文章

  1. 安波副教授:分布式人工智能进展与趋势
  2. 你的生产型ML复现不了,可能是工作流程出了问题
  3. K项目轶事之开工第一天
  4. 谷歌兄弟公司Wing将于10月开始试点无人机配送
  5. 机器学习 | 强化学习,解决决策问题的行家(上)
  6. IBM发布人脸识别最强工具,多样性数据集,100万张人脸图像!
  7. 深度学习领域四个不可不知的重大突破
  8. BAT面试题9:谈谈判别式模型和生成式模型?
  9. 免费教材丨第52期:人工智能(复杂问题求解的结构和策略)、人工智能哲学
  10. (深入理解)强化学习中Model-based和Model-free的区别是什么