广告
返回顶部
首页 > 资讯 > 精选 >JavaScript是怎么验证URL的
  • 923
分享到

JavaScript是怎么验证URL的

2023-07-05 06:07:48 923人浏览 独家记忆
摘要

本篇内容主要讲解“javascript是怎么验证URL的”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“JavaScript是怎么验证URL的”吧!URL验证URL验证的存在是为了加强安全,防止可

本篇内容主要讲解“javascript是怎么验证URL的”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“JavaScript是怎么验证URL的”吧!

URL验证

URL验证的存在是为了加强安全,防止可能存在的漏洞,并消除运行代码时产生的任何错误的机会。但是我们应该在什么时候使用URL验证,在这个过程中我们要验证什么呢?我们应该在所有必须识别和验证诸如网页、图片、gif和视频等资源的软件中实施URL验证。

一个典型的URL包括多个片段,比如协议、域名、主机名、资源名、URL源、端口等等。这些用来告诉浏览器如何追踪指定的资源。我们可以以不同的方式来验证URL:

  • 使用正则字面量和构造函数

  • URL构造函数

  • isValidURL方法

  • Input元素

  • Anchor标签方法

一个典型的URL验证方案接收来自用户的输入,然后对其进行解析,以识别其各个组成部分。验证方案可以确保所有的URL组件符合互联网标准。例如,如果需要,它可以检查URL是否使用安全协议。

主机名验证首先是将主机名分成独立的标签,以确保它们符合顶级域名规范。一个典型的主机名由至少两个用点分隔的标签组成。例如,www.snyk.com 有 "www"、"snyk"和 "com"的标签。每个标签只能由一个字母数字字符或一个连字符组成,无论大小写。然后,验证方案可以确保主机名与URL的允许列表相匹配,以确保只允许指定的URL,并且允许的URL不会被错误地取消资格。

默认情况下,URL中使用的大多数资源的路径都是允许的。然而,端口只能在1到65536的范围内。任何超出这个范围的东西都应该抛出一个错误。我们还可以检查数字IP地址,以判断它是一个IPV4地址还是IPV6地址。

最后,我们也可以检查URL的用户名和密码。这个功能有助于遵守公司政策和凭证保护。

现在,你已经有了这些基础知识,让我们来看看使用javascript的URL验证吧。

如何执行URL验证

在JavaScript中,执行URL验证最简单的方式是使用new URL构造函数。除此之外,它还得到了node.js运行时和大多数浏览器的支持。

基本语法如下:

new URL (url)new URL (url , base)

如果提供相对URL,JavaScript只需要base元素。如果不提供相对URL,默认为undefined。另外,如果提供一个具有绝对URL的base元素,JavaScript会忽略base元素。

为了验证URL,可以使用以下代码:

function checkUrl (string) {  let givenURL ;  try {      givenURL = new URL (string);  } catch (error) {      console.log ("error is", error);     return false;   }  return true;}

该函数用于检查URL的有效性。当URL有效时返回true,否则返回false

  • 如果你传递www.urlcheck.com给该函数会返回false。因为该参数并不是一个有效的URL。正确版本应该是https://urlcheck.com

  • 另一个例子是mailto:John.Doe@example.com。这是一个有效的URL,但如果移除了冒号,JavaScript就不再认为它是一个URL了。

  • 第三个例子是ftp://。这不是一个有效URL,因为没有包含主机名。如果你添加两个点(..),就会变成有效URL。因为点会被认为是一个主机名,也就是说ftp://..变成了一个有效的URL。

重要的是要记住,非常规的、但完全有效的URL是存在的!它们可能对从事这些工作的开发人员来说是意外的,但在其他方面是完全合适的。例如,以下两个URL都会返回真值:

  • new URL("youtube://a.b.c.d");

  • new URL("a://1.2.3.4@1.2.3.4");

这些例子提醒我们,开发者应该依靠URL验证原则,而不是专注于惯例。

如果你想确保有效的URL包含一些特定的URL方案,你可以使用以下函数:

function checkHttpUrl(string) {  let givenURL;  try {      givenURL = new URL(string);  } catch (error) {      console.log("error is",error)    return false;    }  return givenURL.protocol === "http:" || givenURL.protocol === "https:";}

该函数验证URL,然后检查URL是否使用HTTP或者HTTPS。在这里,ftp://..会被认为是无效的,因为它不包含HTTP或者HTTPS,而http://..依旧有效。

使用URL构造函数的一些其他方式包括:

let m = '<https://snyk.io>';let a = new URL("/", m);

上述示例使用了base元素。记录下这个值,我们就可以得到https://snyk.io/

要返回一个URL对象而不指定base参数的话,语法是:

let b = new URL(m);

为了给主机添加一个路径名,我们的代码结构如下:

let d = new URL('/en-US/docs', b);

存储在变量d上的URL是https://snyk.io/en-US/docs

URL模块的另一个功能是,它实现了WHATWG URL api,它遵守WHATWG的URL标准,供浏览器使用:

let adr = new URL("<https://snyk.io/en-US/docs>");let host = adr.host;let path = adr.pathname;

在上面的例子中,我们创建了一个名为adr的URL对象。接着,代码获取URL的主机和路径名,分别是snyk.io/en-US/docs。最后,我们可以将URL和允许列表或者黑名单进行对比,确保只有特定URL是被允许的。

如何使用正则验证

另一种验证URL的方法是使用正则表达式(regex)。我们可以使用Regex来检查URL是否有效。

使用regex进行URL验证的JavaScript语法是:

function isValidURL(string)   {      var res =       string.match(/(https?:\/\/(?:www\.|(?!www))[a-zA-Z0-9][a-zA-Z0-9-      ]+[a-zA-Z0-9]\.[^\s]{2,}|www\.[a-zA-Z0-9][a-zA-Z0-9-]+[a-zA-Z0-9]      \.[^\s]{2,}|https?:\/\/(?:www\.|(?!www))[a-zA-Z0-9]+\.[^\s]{2,}|w      ww\.[a-zA-Z0-9]+\.[^\s]{2,})/gi);  return (res !== null);  };

测试一些URL:

var tc1 = "<http://helloworld.com>"console.log(isValidURL(tc1));

regex定义的URL语法检查URL是否以http://https://或子域开始,以及是否包含域名。控制台上的语句结果是true,因为它遵循了由regex定义的URL语法。相反,下面的语句将返回一个false,因为它没有以任何允许的方案或子域开始,也不包含域名:

var tc4 = "helloWorld";console.log (isValidURL(tc4));

上面的正则表达式相对简单,但仍然难以驾驭。这也是一个容易出错的方法,因为一个正则表达式不能充分处理验证URL的规则。它最多只能做到匹配有效的URL。此外,当一个正则表达式要么包含复杂的验证逻辑,要么收到冗长的输入字符串时,执行验证检查就变得很耗时。

为了满足定义的正则表达式验证检查,浏览器必须在输入字符串中进行数以百万计的回溯。如此多的回溯检查可能会导致"灾难性的回溯",这种现象是复杂的正则表达式会冻结浏览器或使CPU核心进程爆满。

安全使用JavaScript

正如SSRF被添加到新的OWASP Top 10中所证明的那样,URL验证对于JavaScript应用程序的安全性已经变得越来越关键。幸运的是,我们可以通过在服务器端验证URL来帮助缓解此类攻击。此外,根据验证和处理URL的首选方式来使用new URL函数会非常有益。

在看到new URL函数的一些使用案例后,我们学习了如何用正则表达式验证一个URL--并看到了为什么这种方法很麻烦而且容易出错。

URL的安全风险与其说是关于其有效性,不如说是关于危险的URL方案。因此,我们需要确保让服务器端的应用程序进行验证。攻击者可以绕过客户端的验证机制,所以仅仅依靠它并不是解决办法。

到此,相信大家对“JavaScript是怎么验证URL的”有了更深的了解,不妨来实际操作一番吧!这里是编程网网站,更多相关内容可以进入相关频道进行查询,关注我们,继续学习!

--结束END--

本文标题: JavaScript是怎么验证URL的

本文链接: https://www.lsjlt.com/news/349909.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • JavaScript是怎么验证URL的
    本篇内容主要讲解“JavaScript是怎么验证URL的”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“JavaScript是怎么验证URL的”吧!URL验证URL验证的存在是为了加强安全,防止可...
    99+
    2023-07-05
  • 详解JavaScript是如何验证URL的
    目录前言URL验证如何执行URL验证如何使用正则验证安全使用JavaScript前言 当开发者需要为不同目的以不同形式处理URL时,比如说浏览器历史导航,锚点目标,查询参数等等,我们...
    99+
    2023-02-24
    JavaScript验证URL方法 JavaScript验证URL JavaScript URL
  • JavaScript怎么验证API
    今天小编给大家分享一下JavaScript怎么验证API的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。约束验证 DOM 方法...
    99+
    2023-06-26
  • JavaScript怎么验证API约束和验证DOM
    这篇文章主要介绍“JavaScript怎么验证API约束和验证DOM”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“JavaScript怎么验证API约束和验证DOM...
    99+
    2022-10-19
  • javascript怎么制作验证码
    本篇内容介绍了“javascript怎么制作验证码”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成! ...
    99+
    2022-10-19
  • javascript怎么实现Host验证
    近年来,随着互联网技术的不断发展和网络安全的日益重要,越来越多的网站开始使用一些验证机制来保护自己的数据安全。其中,验证 Host 通常是最基本的一种。什么是 Host?首先,我们需要了解一下 Host 是什么意思。在计算机网络中,Host...
    99+
    2023-05-14
  • javascript表单验证是否为空怎么实现
    这篇“javascript表单验证是否为空怎么实现”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“javascript表单验证...
    99+
    2023-07-06
  • JavaScript表单验证怎么完成
    本文小编为大家详细介绍“JavaScript表单验证怎么完成”,内容详细,步骤清晰,细节处理妥当,希望这篇“JavaScript表单验证怎么完成”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学...
    99+
    2022-10-19
  • JavaScript怎么实现表单验证
    这篇文章主要介绍“JavaScript怎么实现表单验证”,在日常操作中,相信很多人在JavaScript怎么实现表单验证问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”JavaScript怎么实现表单验证”的疑...
    99+
    2023-07-02
  • Golang实现验证一个字符串是否为URL
    目录前言官方 URL 包使用 ParseRequestURI使用 url-verifier 包使用 govalidator 包正则表达式匹配总结前言 在实际开发过程中,有时候会遇到 ...
    99+
    2023-05-16
    Golang验证字符串是否为URL Golang验证字符串 Golang 字符串 URL
  • go gin+token验证是怎么实现登陆验证
    本篇文章为大家展示了go gin+token验证是怎么实现登陆验证,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。1.准备go get github.com/dgrija...
    99+
    2023-06-22
  • Javascript中怎么实现表单验证
    这篇文章将为大家详细讲解有关Javascript中怎么实现表单验证,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。1.表单项不能为空: ﹤ scri...
    99+
    2022-10-19
  • 怎么用javascript实现前端验证
    本教程操作环境:Windows10系统、javascript1.8.5版本、Dell G3电脑。怎么用javascript实现前端验证?使用Javascript进行前端验证:设计简单的用户注册页面,其中包括“请输入密码”和“请再次输入密码”...
    99+
    2023-05-14
    验证 JavaScript
  • 如何验证数据库中URL的有效性
    这篇文章将为大家详细讲解有关如何验证数据库中URL的有效性,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。曲库中一些歌曲的URL虽然存在,但是根据URL已经下载不到音乐了.Nginx显示404...
    99+
    2023-06-03
  • PHP如何验证表单中的邮件和URL
    本篇内容介绍了“PHP如何验证表单中的邮件和URL”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!正则表达式正则表达式是一种描述一段文本规则的...
    99+
    2023-06-25
  • javascript表单验证是否为空
    随着网络技术的不断发展,越来越多的网站开始使用表单来收集和处理用户数据。然而,在用户填写表单的过程中,可能会出现某些字段为空的情况,这会给后续数据处理和分析带来困难。因此,合理的表单验证机制是必不可少的。在本文中,我们将介绍JavaScri...
    99+
    2023-05-16
  • 怎么用JavaScript实现滑块验证码
    本篇内容主要讲解“怎么用JavaScript实现滑块验证码”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“怎么用JavaScript实现滑块验证码”吧!效果:鼠标在底部滑块上按下按住不松拖动可以移...
    99+
    2023-06-25
  • javascript中怎么验证form表单数据
    javascript中怎么验证form表单数据,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。直接po截图和代码下面是Check...
    99+
    2022-10-19
  • JavaScript中怎么生成随机验证码
    这篇文章将为大家详细讲解有关JavaScript中怎么生成随机验证码,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。利用canvas制作一个随机验证码:  1...
    99+
    2022-10-19
  • JavaScript怎么实现输入验证判断
    这篇文章主要讲解了“JavaScript怎么实现输入验证判断”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“JavaScript怎么实现输入验证判断”吧! ...
    99+
    2022-10-19
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作