明輝手游網(wǎng)中心:是一個(gè)免費(fèi)提供流行視頻軟件教程、在線學(xué)習(xí)分享的學(xué)習(xí)平臺(tái)!

URL與URI的有什么區(qū)別

[摘要]初學(xué)http協(xié)議,就被這兩個(gè)相似的術(shù)語搞蒙了,查了很多資料,總算搞清楚了。(找資料還是英文啊,靠譜。。。)。 一直存在很多技術(shù)上的爭(zhēng)論,其中最為妙的恐怕就是web地址應(yīng)該叫什么的問題。通常情...
初學(xué)http協(xié)議,就被這兩個(gè)相似的術(shù)語搞蒙了,查了很多資料,總算搞清楚了。(找資料還是英文啊,靠譜。。。)。

URL和URI的有什么區(qū)別

一直存在很多技術(shù)上的爭(zhēng)論,其中最為妙的恐怕就是web地址應(yīng)該叫什么的問題。通常情況就是這樣:有人把地址欄的內(nèi)容叫“URL”,這時(shí)候有些人就來勁了:“不!其實(shí)那時(shí)URI。。!

對(duì)于這種糾正的反應(yīng)呢,通常也有這么幾種情況,心眼小的就尋思這人趕緊走吧,淡定點(diǎn)的就聳聳肩表示同意,火氣大的就拔刀相向了好不?

那這篇文章呢,就對(duì)這個(gè)只是提供一個(gè)簡(jiǎn)單的總結(jié),畢竟互黑也要黑到點(diǎn)子上是吧。

URI,URL,URN

從上面的那幅圖可以看出來,一共有三個(gè)不同的概念URI,URL,URN。這討論這樣的問題時(shí),最好的方法就是回到原點(diǎn)啊,這里我們?cè)赗FC 3986: Uniform Resource Identifier (URI): Generic Syntax里面收集了點(diǎn)資料:

“A Uniform Resource Identifier (URI) 是一個(gè)緊湊的字符串用來標(biāo)示抽象或物理資源!

“A URI 可以進(jìn)一步被分為定位符、名字或兩者都是. 術(shù)語“Uniform Resource Locator” (URL) 是URI的子集, 除了確定一個(gè)資源,還提供一種定位該資源的主要訪問機(jī)制(如其網(wǎng)絡(luò)“位置”)!

那我們無所不知的維基百科把這段消化的很好,并描述的更加形象了:

“URI可以分為URL,URN或同時(shí)具備locators 和names特性的一個(gè)東西。URN作用就好像一個(gè)人的名字,URL就像一個(gè)人的地址。換句話說:URN確定了東西的身份,URL提供了找到它的方式。”

通過這些描述我們可以得到一些結(jié)論:

  • 首先,URL是URI的一種(通過那個(gè)圖就看的出來吧)。所以有人跟你說URL不是URI,他就錯(cuò)了唄。但也不是所有的URI都是URL哦,就好像蝴蝶都會(huì)飛,但會(huì)飛的可不都是蝴蝶啊,你讓蒼蠅怎么想!

  • 讓URI能成為URL的當(dāng)然就是那個(gè)“訪問機(jī)制”,“網(wǎng)絡(luò)位置”。e.g. http:// or ftp://.。

  • URN是唯一標(biāo)識(shí)的一部分,就是一個(gè)特殊的名字。

  下面就來看看例子吧,當(dāng)來也是來自權(quán)威的RFC:

  • ftp://ftp.is.co.za/rfc/rfc1808.txt (also a URL because of the protocol)

  • http://www.ietf.org/rfc/rfc2396.txt (also a URL because of the protocol)

  • ldap://[2001:db8::7]/c=GB?objectClass?one (also a URL because of the protocol)

  • mailto:John.Doe@example.com (also a URL because of the protocol)

  • news:comp.infosystems.www.servers.unix (also a URL because of the protocol)

  • tel:+1-816-555-1212

  • telnet://192.0.2.16:80/ (also a URL because of the protocol)

  • urn:oasis:names:specification:docbook:dtd:xml:4.1.2

  這些全都是URI, 其中有些事URL. 哪些? 就是那些提供了訪問機(jī)制的.

總結(jié)

下面到了回答問題的時(shí)候了:

當(dāng)我們替代web地址的時(shí)候,URI和URL那個(gè)更準(zhǔn)確?

基于我讀的很多的文章,包括RFC,我想說URI更準(zhǔn)確。

別急,我有我的理由:

我們經(jīng)常使用的URI不是嚴(yán)格技術(shù)意義上的URL。例如:你需要的文件在files.hp.com. 這是URI,但不是URL–系統(tǒng)可能會(huì)對(duì)很多協(xié)議和端口都做出正

確的反應(yīng)。

#######################################3

Java中獲取一個(gè)瀏覽器訪問地址信息

3 request
    * request對(duì)象,tomcat根據(jù)http協(xié)議的請(qǐng)求的內(nèi)容,將相應(yīng)的數(shù)據(jù)封裝到request對(duì)象中。
    * request和response必須是成對(duì)出現(xiàn),先有的request,再有的response
    * 接口:javax.servlet.http.HttpServletRequest extends javax.servlet.ServletRequest
    * 實(shí)現(xiàn)類:tomcat實(shí)現(xiàn),并在請(qǐng)求時(shí),tomcat創(chuàng)建 。
    * 請(qǐng)求行
        * 入口:http://localhost:8080/day05/demo/pathRequestServlet?username=jack&password=1234
        * 請(qǐng)求方式
            request.getMethod();
        * 路徑
            // * 請(qǐng)求資源路徑
            // 1 獲得servlet路徑,web.xml配置的url-pattern【★★★】
            String servletPath = request.getServletPath();
            System.out.println(" 1 servletPath -->" + servletPath);  //--> /demo/pathRequestServlet

            //2 獲得發(fā)布到tomcat時(shí)的項(xiàng)目名稱【★★★】
            String contextPath = request.getContextPath();
            System.out.println(" 2 contextPath -->" + contextPath);  //--> /day05

            //3 獲得請(qǐng)求行中的資源路徑
            String requestURI = request.getRequestURI();
            System.out.println(" 3 requestURI -->" + requestURI);//-->/day05/demo/pathRequestServlet

            //4 獲得請(qǐng)求URL(地址欄書寫)
            String requestURL = request.getRequestURL().toString();
            System.out.println(" 4 requestURL -->" + requestURL);//-->http://localhost:8080/day05/demo/pathRequestServlet
            // *** 以上都不獲得get請(qǐng)求的參數(shù)

            //5 獲得get請(qǐng)求的參數(shù),獲得的是所有參數(shù)的一個(gè)字符串
            String queryString = request.getQueryString();
            System.out.println(" 5 queryString -->" + queryString); //-->username=jack&password=1234

        * 協(xié)議
            request.getProtocol();
    * 請(qǐng)求頭
        * java.lang.String getHeader(java.lang.String name) 獲得指定名稱的頭信息(一條)【★★★】
        * long getDateHeader(java.lang.String name) 獲得特殊數(shù)據(jù),時(shí)間
        * int getIntHeader(java.lang.String name) 獲得特殊數(shù)據(jù),整型
        * java.util.Enumeration getHeaderNames() 獲得所有的請(qǐng)求頭的名稱
        * java.util.Enumeration getHeaders(java.lang.String name) 獲得指定名稱頭的所有內(nèi)容
        * 實(shí)例:防盜鏈,(不能直接訪問 /refererTwoServlet)
    * 請(qǐng)求體
        * ServletInputStream getInputStream() 獲得請(qǐng)求體的所有內(nèi)容。(之后講,文件上傳)

    * 核心API
        * 屬性操作
            * xxxAttribute (set / get / remove)  服務(wù)器端【★★★】
        * 獲得參數(shù)
            * 獲得瀏覽器 發(fā)送給 服務(wù)器端的參數(shù)(Parameter)
            * API【★★★】
                * 實(shí)例:url?username=jack&username=rose&username=tom&password=1234
                * getParameter(java.lang.String name) 獲得指定參數(shù)的第一個(gè)值,如果數(shù)據(jù)不存在獲得null 。
                    * 例如:getParameter("username") 獲得 jack
                * java.lang.String[] getParameterValues(java.lang.String name) 獲得指定參數(shù)的所有的值。
                    * 例如:getParameterValues("username") ,獲得[jack,rose,tom]
                * java.util.Map<String,String[]> getParameterMap() 獲得所有的內(nèi)容,key 參數(shù)的名稱 ,value 該參數(shù)的所有的值
                    * 例如:{username=[jack,rose,tom],password=[1234]}
            * 中文亂碼
                * POST請(qǐng)求【★★★】
                    * 設(shè)置 setCharacterEncoding(java.lang.String env) ,設(shè)置字符編碼
                * GET請(qǐng)求
                    * new String(username.getBytes("ISO-8859-1"), "字符集");

以上就是URL和URI的有什么區(qū)別 的詳細(xì)內(nèi)容,更多請(qǐng)關(guān)注php中文網(wǎng)其它相關(guān)文章!


網(wǎng)站建設(shè)是一個(gè)廣義的術(shù)語,涵蓋了許多不同的技能和學(xué)科中所使用的生產(chǎn)和維護(hù)的網(wǎng)站。