javascript-正则表达式匹配出URL地址,批量添加a标签

news2024/10/7 13:24:03

一开始接到这个需求觉得简单,结果越搞越复杂,反复了很多次,没有特别好的解决方案

最近接到一个需求,客服输入框需要将发送出去的消息中含有url地址匹配出来添加上a标签,但是由于输入框是富文本,所以输入框内有可能有各种标签,像a、p标签等。

最开始我在网上找到一个正则表达式,但是会匹配邮箱、数字(类似www123@fenxin.com、123.123、hae.123),后来经过好几轮正则替换。

A同事找的:

 (((ht|f)tps?):\/\/)?[\w\-]+(\.[\w\-]+)+([\w\-.,@?^=%&:/~+#]*[\w\-@?^=%&/~+#])?(?<!@[\w\-]+(\.[\w\-]+)*)

这个不匹配邮箱,但是客户有数字123.123、密码hahh.123这种也会匹配,不确定可能得情况,进行一一排除不太好。

B同事自己写的:

^((https|http)://)?[A-Za-z0-9+&#/%?=~_|!:,.;]+\.(com|net|cn|vip|org|edu|info|gov|top|xyz|html)$

这个只能完全匹配单个url的情况,多个url不匹配、邮箱、数字、ip等不匹配,本想着就这样限制死算了,结果最近又发现富文本消息默认有p标签等,我是将p标签替换掉之后使用正则匹配的,这样本来换行的消息就不换行了,于是又要改正则了。

最终方案:

C同事写的正则(无法排除邮箱,需要加一些限制):
具体逻辑:
首先判断消息中是否有a标签,如果有则原样返回,不做处理

let aExp = /<a.+?href=\"(.+?)\".*>(.+)<\/a>/gi
let textStr = text.replace(/<p>/g,'').replace(/<\/p>/g,'').replace(/&gt;/g,'>').replace(/&lt;/g,'<')
if(aExp.test(textStr)){
   return text
}

如果没有,则判断是否含有邮箱,如果有将邮箱用特殊字符“_$1_temp”替换,然后在进行url正则匹配;最后利用匹配出来的邮箱数组,批量将特殊字符再替换回来。

let exp = /(https?:\/\/)?((((25[0-5])|(2[0-4][0-9])|(1\d{2})|(\d{2})|([1-9]))(\.((25[0-5])|(2[0-4][0-9])|(1\d{2})|(\d{2})|(\d))){2}\.((25[0-5])|(2[0-4][0-9])|(1\d{2})|(\d{2})|(\d)))|((([A-Za-z0-9][A-Za-z0-9\-]{0,19})\.)?([A-Za-z0-9][A-Za-z0-9\-]{0,19})\.([a-z]{2,3})))((:\d{2,5})?)(((\/(\S+)?)+(\.\S+)?)?)((\?(\S+\=\S+)(&(\S+\=\S+))*)?)/gi
let emailExp = /(?:[a-z0-9+!#$%&'*+/=?^_`{|}~-]+(?:\.[a-z0-9!#$%&'*+/=?^_`{|}~-]+)*|"(?:[\x01-\x08\x0b\x0c\x0e-\x1f\x21\x23-\x5b\x5d-\x7f]|\\[\x01-\x09\x0b\x0c\x0e-\x7f])*")@(?:(?:[a-z0-9](?:[a-z0-9-]*[a-z0-9])?\.)+[a-z0-9](?:[a-z0-9-]*[a-z0-9])?|\[(?:(?:25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)\.){3}(?:25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?|[a-z0-9-]*[a-z0-9]:(?:[\x01-\x08\x0b\x0c\x0e-\x1f\x21-\x5a\x53-\x7f]|\\[\x01-\x09\x0b\x0c\x0e-\x7f])+)\])/gi
let emailArr = text.match(emailExp)
let a2 = text.replace(emailExp, function(){
	return '_$1_temp'
}).replace(exp, function(a){
	if(!a.indexOf('http')){
		return '<a href="'+a+'" target="_blank">'+a+'</a>'
	} else {
		return '<a href="http://'+a+'" target="_blank">http://'+a+'</a>'
	}
})
if(emailArr&&emailArr.length>0){
	let result = emailArr.map((item, i) => {
		a2 = a2.replace('_$1_temp',item)
		return a2
	})
	return result[result.length - 1]
} else {
	return a2
}

在这里插入图片描述
在这里插入图片描述
目前这个方法不是太好,如果消息中存在a标签,就没有做其他url替换;正常的逻辑是a标签的url不替换,其他正常的url替换,目前这方式还不知道有没有其他问题。

不知道有没有大佬有完美的解决方案,可以满足匹配富文本消息中所有url批量替换加上a标签;同时不匹配:带有a标签的url、邮箱、123.23、haha.123、123.123.123等不是真正url的字符串,富文本消息中的标签正常返回,不影响换行等样式。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/742489.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

优秀的 RocketMQ 可视化管理工具 GUI 客户端

优秀的 RocketMQ 可视化管理工具 GUI 客户端 官网地址&#xff1a;http://www.redisant.cn/rocketmq 快速查看所有 RocketMQ 集群&#xff0c;包括Brokers、Topics和Consumers查看消费者订阅了哪些主题&#xff0c;以及消息队列被分配给了哪些消费者&#xff1b;当出现消息积…

插入排序和希尔排序:用C语言打造高效的排序算法

插入排序 插入排序的思路就像是你在整理一堆扑克牌。你先拿起第一张牌&#xff0c;然后拿起第二张牌&#xff0c;把它插入到合适的位置&#xff0c;使得你手上的两张牌是有序的。接着&#xff0c;你再拿起第三张牌&#xff0c;也把它插入到合适的位置&#xff0c;使得你手上的…

安装pycharm安装激活教程,不想只使用一个月,也不想花钱?

前言 本文方法可以安装使用截止当前2023.1.3最新版本Pycharm&#xff0c;过程非常简单&#xff0c;按照下面的步骤来一分钟即可搞定。 1.下载安装 已经安装过的可以跳过该步骤&#xff01; 下载 到官网地址下载正版安装包JetBrains Pycharm官网下载地址 安装 开始安装 选择安…

vertical-align详细介绍

1.定义: vertical-align是一个CSS属性&#xff0c;用于指定行内元素或表格单元格中内容的垂直对齐方式。它可以应用于行内元素、表格单元格或表格单元格中的内容。 该属性可以接受多个值&#xff0c;包括关键字&#xff08;如top、middle、bottom&#xff09;&#xff0c;长度…

Autosar诊断实战系列11-UDS 0x27加解密服务配置开发介绍

本文框架 前言1. DcmDsd 0x27服务添加1.1 DcmDsdSubServices中添加子服务2. DcmDsp中DcmDspSecurity实战配置2.1 DcmDspSecurity实战配置2.2 尝试次数及DelayTime进一步理解前言 在本系列笔者将结合工作中对诊断实战部分的应用经验进一步介绍常用UDS服务的进一步探讨及开发中注…

Python3+requests搭建接口自动化测试框架

目录 一、接口自动化的意义&#xff08;为什么做这个框架&#xff09; 二、准备工作 三、框架流程及逻辑 四、各模块介绍 五、具体使用 一、接口自动化的意义&#xff08;为什么做这个框架&#xff09; 新版本上线时之前版本的功能需要进行回归测试&#xff0c;导致大量的…

对文件中的数据进行排序

#include<stdio.h> #include<stdlib.h> #include<time.h> int main()//生成1000个随机数据 {srand((size_t)time(NULL));FILE* fpfopen("d:/data.txt","w");if(!fp) return -1;for(int i0;i<1000;i)fprintf(fp,"%d\n",ran…

【Git】保姆级教程:如何在 GitHub 上传大文件(≥100M)?(含自己的操作流程)

文章目录 一、问题导读二、自己的实际操作流程2.1 准备工作2.2 初始化仓库2.3 安装git lfs&#xff08;一个仓库里面执行一次就好了&#xff09;2.4 跟踪一下你要上传&#xff08;push&#xff09;的文件或指定文件类型2.5 添加.gitattributes2.6 添加要上传&#xff08;push&a…

Jmeter上传文件接口测试

Jmeter上传文件接口测试 接口测试&#xff0c;想必大家都做过&#xff0c;但是上传文件的接口&#xff0c;可能就不知所措。其实呢&#xff0c;还是那么回事~ 一、接口的业务 在接口文档缺失的前提下&#xff0c;那就从抓包玩起~Fiddler或者F12都可以。 本次我们接口实现的…

springboot+mysql实现特产销售平台

本次设计任务是要设计一个藏区特产销售平台&#xff0c;通过这个系统能够满足藏区特产销售管理的管理功能。系统的主要包括首页、个人中心、用户管理、特产信息管理、特产分类管理、特产分类管理、特产评分管理、系统管理、订单管理等功能。 管理员可以根据系统给定的账号进行登…

Graphics笔记

1.简介 Graphics是System.Drawing里面的绘图类。 2.开始绘制 2.1.创建绘图对象&#xff0c;三种方法 在窗体或控件的Paint事件中&#xff0c;用PaintEventArgs创创建绘图对象(控件或窗体重绘时&#xff09; /// <summary>/// 1.在窗体或控件的Paint事件中&#xff0c…

以数字孪生技术服务社会,推动企业高质量发展

随着“十四五”规划和2035年远景目标纲要中提出&#xff0c;要加快数字化发展&#xff0c;建设数字中国。为建设数字孪生智慧城市提供了国家战略指引。 新兴技术是数字孪生发展的助推剂&#xff0c;臻图信息通过数字孪生技术及研发的实景三维渲染引擎&#xff0c;搭载自主研发的…

IP地址【图解TCP/IP(笔记十)】

文章目录 IP地址的基础知识IP地址的定义IP地址由网络和主机两部分标识组成IP地址的分类广播地址IP多播子网掩码 IPv4首部 IP地址的基础知识 在用TCP/IP通信时&#xff0c;用IP地址识别主机和路由器。为了保证正常通信&#xff0c;有必要为每个设备配置正确的IP地址。在互联网通…

使用Gradio库进行交互式数据可视化:Timeseries模块介绍

❤️觉得内容不错的话&#xff0c;欢迎点赞收藏加关注&#x1f60a;&#x1f60a;&#x1f60a;&#xff0c;后续会继续输入更多优质内容❤️ &#x1f449;有问题欢迎大家加关注私戳或者评论&#xff08;包括但不限于NLP算法相关&#xff0c;linux学习相关&#xff0c;读研读博…

计算机体系结构基础知识介绍之硬件预测(二)

一、ROB详述 指令执行的四个步骤是&#xff1a; 发射&#xff08;Issue&#xff09;&#xff1a;从指令队列中获取一条指令。如果有空闲的保留站和ROB条目&#xff0c;就发射指令&#xff1b;如果寄存器或ROB中有可用的操作数&#xff0c;就发送操作数到保留站。更新控制字段…

gigachad1靶机详解

gigachad_vh靶机详解 扫描到ip后对ip做一个全面扫描&#xff0c;发现有一个匿名服务器&#xff0c;是可以免密登陆的。 登陆上后发现就一个文件&#xff0c;get到我们电脑上。 file一下发现是一个zip文件&#xff0c;unzip解压一下&#xff0c;发现给了一个用户名chad&#xf…

ESP32设备驱动-直流电机与L298N电机驱动器

直流电机与L298N电机驱动器 文章目录 直流电机与L298N电机驱动器1、L298N介绍2、硬件准备3、软件准备4、驱动实现在本文中,我们将介绍如何使用ESP32通过L298N电机驱动器驱动直流电机。 1、L298N介绍 L298N 电机驱动器模块非常易于与微控制器一起使用,而且相对便宜。 它被广泛…

基于springboot的微信小程序宠物领养医院系统(源代码+数据库+10000字论文)085

基于springboot的微信小程序宠物领养医院系统(源代码数据库10000字论文)085 一、系统介绍 本项目有网页版和小程序端 本系统分为管理员、医生、用户三种角色 用户角色包含以下功能&#xff1a; 登录、注册、宠物领养、医生在线咨询、查看挂号、个人中心、密码修改、宠物寄…

HTTP第18讲——HTTP的缓存控制

诞生背景 由于链路漫长&#xff0c;网络时延不可控&#xff0c;浏览器使用 HTTP 获取资源的成本较高。所以&#xff0c;非常有必要把“来之不易”的数据缓存起来&#xff0c;下次再请求的时候尽可能地复用。这样&#xff0c;就可以避免多次请求 - 应答的通信成本&#xff0c;节…

测试工程师简历编写指南,送简历模板

目录 概述 简历元素 1. 基础信息 2. 个人情况 3. 教育背景 4.专业技能 5.工作经历&项目经 6. 自我评价&兴趣爱好 7. 其他内容 总结&#xff1a; 概述 在人才市场中&#xff0c;一次完整的求职过程通常包括以下阶段&#xff1a; 简历筛选电话面试笔试面谈意向…