zoukankan      html  css  js  c++  java
  • url网址解析的好帮手

    接下来进入node的重点,也就是介绍nodejs主要api的功能和如果使用,由于nodejs逐渐能满足这种高并发和大规模的场景。
    他才被更多的公司所采用

    无论什么资源,一定要有明确的地址才有意义,在互联网里面的具体地址就由url来表示,互联网上的一个图片,一个地址,一首
    音乐,都会有一个唯一都一个地址,我们一般通过url来访问到它

    说到url,就要提一下uri,经常有人搞不清楚两者的区别,uri是统一资源标识符,url是统一资源定位符,什么意思呢
    uri偏重的是标识,url偏重的是定位,比如网址就是url,是一个具体的符号,说明了要通过哪种协议来访问这个资源
    uri更抽象一些,是一个字符串格式规范,是一种概念上的定义,事实上呢,url是uri的一个子集,url肯定是uri,但
    uri不一定是url,在我们生活中,分分钟都在url,比如去淘宝网,去百度,去优酷,他们的网址肯定是烂熟于心
    那url也有一些他的命名规则,一般来说,url只能用英文字母,符号,和阿拉伯数字和某些标点符号,不能使用其他文字和符号
    那如果有文字就必须编码,url的编码就是另外一个可以展开的话题了,我们还是直接回到nodejs里面,看看url这个模块
    都能干啥

    首先,要找到url这个模块的文档,进入官网后,找到url,可以找到很多相应的方法

    我们先看这三个方法

    他们分别是用来干嘛的呢
    parse顾名思义,就是用来解析一个url地址的,url.parse()方法会解析一个url字符串并返回一个url对象
    format呢就是将一个url对象转化成一个url字符串
    resolve也是用来解析的,只不过它接收两个参数,把两个参数拼接成浏览器可以识别的格式

    parse

    接下来来命令行里面演示一下,首先是parse
    比如这个地址:https://nodejs.org/dist/latest-v10.x/docs/api/url.html
    输入

    node

    进入nodejs的环境,直接打印

    url

    就能看到一些里面的一些可用的方法,我们输入

    铛铛,就能看到url地址被解析成了对象,我们看下标准的url的组成部分,首先是这个
    protbcal,它指定的是底层使用的协议是http还是ftp。
    auth,URL的用户名与密码部分。该字符串跟在protocol和双斜杠(如果有)的后面,排在 host 部分的前面且被一个 ASCII 的 at 符号(@)分隔
    slashes,是否有协议的双斜线
    host,表示ip地址 或者 域名
    port,端口,默认是80端口,如果是其他端口,就必须指明
    hostname,主机名
    hash,通常对应的是所谓的锚,页面上某个锚点的那种,加#之后,把页面滚动到当前位置到这种
    search,查询字符串参数
    query,发送给http服务到一个数据,通常称这个被=分隔到键值称为参数串
    pathname,访问资源路径名
    path,访问资源路径
    href,没被解析的完整的超链接
    无论多么复杂的url,只要是合法的,都可以这样被解析


    format
    接下来看format怎么用,我们刚才通过parse解析后的对象拿到format里面,看能不能生成一个标准的url地址

    可以看到已经生成,而且是合法的url地址

    resolve
    继续来试一下resolve,第一个参数放一个首页地址,后面跟上这个hash,就是这个路径,然后回车得到

    一个合法的url地址


    这个url模块非常简单,却非常的重要,主要设计到网络到请求的接受,路径参数的处理就能用到它,非常方便到简析出这个url的组成部分
    从而识别这个请求类型以及来判断如何来返回数据,它会是学习node url的好帮手,特别是parse真的特别好用

    parse可以加入两个参数,来实现不同的目的,接下来演示一下,第一个参数是刚才所构造的带参数的url地址,第二个参数是用来指定,
    用来解析这个query这个模块使用queryString这个module还是自身的这个,如果设置成true的话,就会用queryString这个module
    默认的值是false

    能看到这个query已经被解析成了一个对象,但是search他还是一个string,他没有任何的变化,但query变成一个对象,之前不传true的
    query它也是一个字符串,所以这个区别一眼就能够看的很清楚了


    我们看这个方法所接收的第三个参数,用来处理这种场景,有些时候我们并不知道这个来源地址是什么协议的,他可能是一个http,也可能
    是一个https的,那这个时候我也想取到这里面的路径和这里面的query,那这个时候就不能解析,出错,那这种也可以不写前面的协议,
    也通过这种方式去解析,那就通过添加这个第三个参数,他默认是false,如果指定为true的话

    可以对比上面的和下面的有什么不同,上面的host为null,就是解析失败,下面的host解析出来就是我们所希望的nodejs.org,另外就是
    pathname,上面就整个当成这个路径,下面就是解析正确后的一个希望的路径,所以根据大家的需求来怎么判断传递的这个参数

  • 相关阅读:
    我理解的朴素贝叶斯模型
    P2P贷款全攻略,贷前、贷中、贷后工作事项解析
    Jupyter Notebook 快速入门
    R语言|数据特征分析
    R语言︱处理缺失数据&&异常值检验、离群点分析、异常值处理
    mysql explain执行计划详解
    R语言中的回归诊断-- car包
    一行代码搞定 R 语言模型输出!(使用 stargazer 包)
    基于R语言的时间序列指数模型
    基于R语言的ARIMA模型
  • 原文地址:https://www.cnblogs.com/wzndkj/p/9075061.html
Copyright © 2011-2022 走看看