http学习笔记(二)—— 嘿!伙计,你在哪?(URL)

 我们之所以希望浏览网页,其中一个重要的原因就是庞大的web世界中有很丰富的资源,他就像哆啦a梦的口袋,随时都能拿出我们想要的宝贝。这些资源通过http被传送到我们的浏览器,并展示到我们的屏幕上。而我们之所以可以准确地找到这些资源,是URL(UniformResourceLocator,统一资源定位符)帮我们确定了它们(资源)的位置。

  

  在没有 url 之前,我们想获取资源,必须要先想办法,连接到一个服务器上去,这个过程中可能还需要登陆,然后在服务器上找到目录,然后切换成二进制模式,这样才可以获得自己的资源。这个过程很繁琐,而且,用户也不一定会使用。直到互联网之父蒂姆·伯纳斯·李(就是在伦敦奥运会开幕式上打出this is for everyone的大师)发明了URL。

URL初窥

比如这是一个完整的地址:

  http://www.abc.com/index.html

URL将这个整个地址分成了三个部分:

  ①方案  ②主机名 ③资源路径

其中 :

  http:// 是方案,它规定了我们使用哪种方式访问目标地址。

  www.abc.com 是目标主机名  实际上它会被DNS服务器解析为一个IP地址。

  最后index.html 是资源的路径。

现在来详细地看看这些东西。

URL语法

几乎所有的URL都遵循规定的URL语法:

  <scheme>://<user>:<password>@<host>:<port >/<path>;<params>?<query>#<frag>

接下来我们详细地看看每个部分:

<scheme>(方案):

  在巨大的网络世界里有很多服务器(比如samba、ftp、mail等等),每种服务器都有一些特定的服务方式访问它们。比如我们在访问ftp服务器时可能会输入:

  ftp://www.abc.com

  ftp:// 在这里就是我们使用的传输协议,这也是url告诉服务器要采用什么方案来传输资源一种方式。这就好像我们放假约哥们儿出去喝酒,你打电话给他,他总不能拿邮箱接电话吧。

<user>:<password>

至于账号和密码,这个很好理解,假如我们在学校或者公司有ftp服务器,它有时会要求用户输入一个登录名和一个密码来登陆到ftp。通过url访问这个服务器时候,用户名和密码就会被加在这个地方。

<host>:<port >

  主机就是客户端要访问的目标服务器。

  端口就是目标服务器上为客户端提供的服务使用的监听端口,最典型的就是web服务器的80端口。服务器通过端口准确地确定客户端需要的资源从哪个服务获取。

<path>

路径说明了这个资源在这个服务使用的目录下的位置

<params>

  参数,有些方案不仅仅满足于账户和密码提供的信息,他们需要更多的参数来确定传输的方式。这些参数用   ;     号和URL其他部分分开

  比如:   ftp:/www.abc.com;type=d

  这个例子中  type是参数名   d是这个参数的名字。服务器端的服务程序接收到这个url 请求后,知道用type 采用d模式

<query>

  相信学习web的童鞋一定都用过问号传值, 我们常常通过这个查询组件,确定数据库查询的范围,并确定客户端希望获得的资源。并且和参数一样,查询不局限于一个单一的参数。他们可以通过&连接符传递多个查询。

  比如: http://www.abc.com/xxx.html?type1=value1&type2=value2&type3=value3

<frag>

  最后这个片段,相信大家也一定不会陌生,它就像我们在看电子书时用的书签。在这个页面中的某一个部分,开发者给他定义一个名字,当用户打开这个页面想访问这个部分的时候,通过这个片段组件找到这个片段。就好像喊一下这个片段的名字,它就立马就跑到我们前面来了。

  这个组件还是很有用的。有时候用户需要访问一个篇幅很长的页面,而他们并不想阅览所有的内容,用户只是想看到他们需要的部分,如果使用滚动条的方式阅读找到这些内容会很吃力。但是网站的设计者在页面中为某一部分设定了名字,那用户很快就可以找到这些内容了。

以上就是url的一些解释了。

相对路径

之前所了解的都是绝对路径。现在来看看相对路径。

假如在开发一个页面时,我们写访问路径,每次都要写下一个完整的URL,那简直是太残暴了。

况且我们开发时很少知道这个开发的页面,未来会用什么域名,这个站点的所有文件未来会被摆放到什么位置。相对路径解决了这个问题。假设我们访问这个路径:

www.abc.com/index.html

而这个页面中有一个连接指向 www.abc.com/page1.html

在index.html中的连接就可以这么写 <a href=”./page1.html”></html>

浏览器会自动补齐页面的路径,下面是一个例子:

这个是一个简单的页面中的一个图片链接

经过浏览器整理之后它就变成了

这个相对路径后面也可以进行参数、片段、查询字符串的使用。

当然浏览器不可能凭空补全这个路径:找到它基础URL这两种方式:

1、在html文档中显示地使用一个<base>标签标记。所有相对URL通过这个<base>中定义的路径来补齐绝对路径

2、如果没有这个<base >标签,那么浏览器就会把当前页面的URL作为基础。

通过URL,我们很方便地就找到了自己想要的资源,甚至大多数用户都不用知道他们需要使用什么协议和方法,就可以很轻松地对资源说:嘿!伙计,我找到你了!

 
 

http学习笔记2(URL)的更多相关文章

  1. thinkphp学习笔记6—url模式

    原文:thinkphp学习笔记6-url模式 入口文件是应用的唯一入口,因为可以多入口,每个应用可以对应一个入口文件,系统会从rul参数中解析当前请求的模块,控制器,操作.ThinkPHP是区分大小写 ...

  2. 学习笔记:URL Protocol在浏览器中打开本地应用程序

    看到阿里的网站上可以通过点击卖家的旺旺图标从而调用本地的阿里旺旺程序,而且还可以传递当前浏览者需要咨询的商品.这是怎么实现的呢?是通过URLProtocol来完成. 原理还没有太清楚,即在系统里注册一 ...

  3. node.js在windows下的学习笔记(10)---URL模块

    1.parse函数的作用是解析url,返回一个json格式的数组 url.parse('http://www.zjut.edu.cn'); { protocol: 'http:', slashes: ...

  4. Django学习笔记之URL与视图

    视图 视图一般都写在app的views.py中.并且视图的第一个参数永远都是request(一个HttpRequest)对象.这个对象存储了这个http请求的所有信息,其中包括携带的参数以及一些头部信 ...

  5. Asp.net core 学习笔记 (操作 url and query params)

    更新 :2018-7-25 直接添加 query string. var resetPasswordLink = QueryHelpers.AddQueryString($"{Request ...

  6. JMeter学习笔记--使用URL回写来处理用户会话

    如果测试的Web应用系统使用URL回写而非Cookie来保存会话信息,那么测试人员需要做一些额外的工作来测试web站点 为了正确回应URL回写,JMeter需要解析从服务器收到的HTML,并得到唯一的 ...

  7. Django学习笔记之URL标签的使用

    期初用django 开发应用的时候,完全是在urls.py 中硬编码配置地址,在views.py中HttpResponseRedirect()也是硬编码转向地址,当然在template 中也是一样了, ...

  8. 7.2(java学习笔记)URL

    一.URL URL类表示统一资源定位符,指向万维网上“资源”的指针. 资源可以是简单的文件或目录,也可以是对更复杂对象的引用,比如对数据库或搜索引擎的查询. URL即是定位也是资源,定位到网络中一个具 ...

  9. NodeJS学习笔记 (14)URL查询字符串-querystring(ok)

    模块概述 在nodejs中,提供了querystring这个模块,用来做url查询参数的解析,使用非常简单. 模块总共有四个方法,绝大部分时,我们只会用到 .parse(). **.stringify ...

  10. MVC4 学习笔记 之 URL中存在编译的空格 20%20%

    /Config/Edit/QQCC%20%20%20%20%20%20%20 原因是: 通过EF直接添加了空格? NO 是因为你的数据库字段设计问题,因为你当然设计如>:sID nchar(10 ...

随机推荐

  1. Swift编程语言学习12 ——实例方法(Instance Methods)和类型方法(Type Methods)

    方法是与某些特定类型相关联的函数.类.结构体.枚举都能够定义实例方法:实例方法为给定类型的实例封装了详细的任务与功能.类.结构体.枚举也能够定义类型方法:类型方法与类型本身相关联.类型方法与 Obje ...

  2. style中position的属性值具体解释

    Position的英文原意是指位置.职位.状态.也有安置的意思.在CSS布局中,Position发挥着非常关键的数据,非常多容器的定位是用Position来完毕. Position属性有四个可选值,它 ...

  3. Struts2_2_第一Struts2应用

    web.xml文件的配置与1同样. 1)HelloWorld类的代码: public class HelloWorldAction { private String message; public S ...

  4. 初创互联网公司简明创业指南 - YC新掌门Sam Altman

    本文只是一个创业指南的简明版 - 更详细的版本请查看:http://startupclass.samaltman.com 创业之前,你更应该去拥有一个好的创意,而不是一个公司.如果开始前你拥有一个好的 ...

  5. 它们的定义android滑动菜单

    在这里实现了两个滑动菜单效果,的拖放内容的第一部分,菜单拖出像这样的效果感觉,另一种是拖动内容.后面的内容固定菜单.我感觉有层次感的效果,如下面 第一种效果的代码实现例如以下: package com ...

  6. 为Pythonic论坛添加一个“专题”功能(续)

    上篇博文<为Pythonic论坛添加一个“专题”功能>,在模板的层次上对发帖进行了限制.也就是根据用户是否拥有权限来决定是否显示发帖框. 但是自从这么“投机取巧”的写完模板后,整夜辗转反侧 ...

  7. UVA10537 Toll! Revisited

    difkstra + 路径输出 The Toll! Revisited Time Limit: 3000MS Memory Limit: Unknown 64bit IO Format: %lld & ...

  8. 分享12款经典时尚的HTML5应用

    分享伟大,呵呵.今天给大家分享一下收集的12个HTML5小特效. 我整理一下源码,给大家打包一下,我博客园上传文件大小有限,传不了了. 需要的请留下邮箱就行了,觉得好的话,不要忘了点赞哦~ 1.CSS ...

  9. Android高仿雅虎天气(两)---代码结构分析

    版本已经升级到1.0.1 源码地址: GitHub:https://github.com/way1989/WayHoo OsChina:http://git.oschina.net/way/WayHo ...

  10. iOS:由URL成员UIImage

    很多时候,我们只能得到URL.然后,需要建立一个UIImage. 在正常情况下,.我们一般通过SDWebImage直接施工UIImageVIew的image,如何使用URL直接施工UIImage它? ...