使用标签模板来解决用户恶意输入问题

简介: 在一些应用场景下,用户输入的内容会显示到页面中,比如文章的发布,等等,这个时候就会出现一个问题。

什么是恶意输入

在一些应用场景下,用户输入的内容会显示到页面中,比如文章的发布,等等,这个时候就会出现一个问题。

比如猪痞恶霸在掘金的文章简介内插入下面的一行代码

<script>
    alert("猪痞恶霸yyds")
</script>
复制代码

这里就不表达出不好的内容了,其实这还不算是严重的问题,如果使用了无限循环alert那就直接死机,又或者将页面跳转到其他页面去,造成进不去的情况

😶‍🌫️用户恶意输入的威胁性可想而知,那么又如何去解决这个问题呢,下面将具体介绍一种通过标签模板来解决的方法

标签模板

概念

标签模板是模板字符串的一种使用方式,可以理解为跟在函数名后的模板字符串,也算是函数的另一种使用形式,可以将模板字符串内部的字符串部分和变量替换部分以参数的形式传递到函数中,就如下面的例子。

let str = "猪痞恶霸",
  _str = "fzf404";
function add(a, ...b) {
  console.log(a);
  console.log(b);
}
add`Hello${str}World${_str}`;
// [ 'Hello', 'World', '' ]
// [ '猪痞恶霸', 'fzf404' ]
复制代码

其参数的转换是有特定的规则,其第一个参数是一个数组的形式,其数组成员为变量部分的两边字符串,如上[ 'Hello', 'World', '' ]其数组包含三个成员,为什么会有空字符串,是因为在第二个变量部分_str"World"与空格之间,所以第三个数组成员为空字符串;第二个参数到第n个参数为变量成员,也可以使用扩展运算符使其为数组,如上[ '猪痞恶霸', 'fzf404' ]

使用

了解了标签模板的使用,那么我们是如何使用标签模板来解决用户恶意输入的问题呢

首先我们声明了一个str变量来模拟用户输入

let str = "<script>alert("猪痞恶霸yyds")</script>"
复制代码

声明一个防御函数,防御函数参考 《ES6标准入门》 ,这里我来讲解下我思考的其函数实现过程:

函数的参数包含两种,一种是字符串成员,一种是变量成员也就是用户输入的内容,首先保存第一个字符串成员,通过使用arguments从第二个参数开始遍历,因为需要在遍历体内进行监测恶意内容替换,所以从变量成员开始遍历,将变量成员通过String()转换为字符串,通过replace方法进行恶意内容的替换再与先前保留的头部字符串成员拼接,比如这里将<>替换为不可被认为成<script>执行但是可以被正常渲染的内容,在结束循环前拼接下一个字符串成员,达到交叉拼接的效果。

function SaferHTML(tempalte) {
  let s = tempalte[0];
  for (let i = 1; i < arguments.length; i++) {
    let arg = String(arguments[i]);
    // Escape special characters in the substitution.
    s += arg.replace(/&/g, "&amp;")
            .replace(/</g, "&lt;")
            .replace(/>/g, "&gt;");
    // Don't escape special characters in the template.
    s += tempalte[i];
  }
  return s;
}
复制代码

最后再通过标签模板执行函数即可

let end = SaferHTML`<p>${str}用户输入${str}</p>`;
复制代码

总体上的实现是依托标签模板的参数特性,达到一个字符串的拼接替换操作。

参考文献

ES6标准入门


相关文章
|
2月前
|
存储 安全 前端开发
Web安全-表单域隐藏
Web安全-表单域隐藏
73 3
|
6月前
视觉智能平台模板视频人脸融合,上传模板之后立即删除模板会报模板id无效,是因为模板还未生成吗?
视觉智能平台模板视频人脸融合,上传模板之后立即删除模板会报模板id无效,是因为模板还未生成吗?
54 1
|
JSON 测试技术 数据格式
[单账户]标签规范工具(标签策略)使用手册
企业随着上云的深入,对于资源管理的诉求越来越强烈。资源被企业各个子公司、部门等使用的时候,存在资源自产自用,一产复用,共产共用的情况。企业发展最初阶段,满足快速发展的诉求,资源自己生产自己使用。当企业发展到一定阶段,存在资源生产多处复用的情况,以满足业务细分发展。再到资源管理统一生产规划、根据场景复用资源的情况。标签化管理资源共产共用的基础,根据用途、场景、归属进行资源分类。如何把资源标签使用规范就是资源分类的前提。
1070 0
|
数据安全/隐私保护
6个绝赞的模板网站,你想要的、这里都有!
提起PPT,应该都不陌生,作为Office三件套之一,它扮演者至关重要的角色。在学生时代如此,在工作之后更为重要。 以我为例,在学生时代没有意识到PPT的重要性,无论是日常开会讨论,还是毕业答辩,我都是随便找出一个简陋的默认版本,贴上一些文字、公式、图片就大功告成。做完一个PPT,前后也用不到半天时间。
6个绝赞的模板网站,你想要的、这里都有!
|
安全 程序员
网站打开被提示该内容被禁止访问的原因分析
最近手机短信和邮箱总是收到阿里云的违规URL通知,意思是网站存在违规URL地址,导致被短信或邮箱通知,关键问题是天天给我发这个通知,实在太烦了,集团网站的领导打电话让我抓紧处理,我可马虎不得就抓紧登录阿里云查看下具体的通知内容,显示如下:
739 0
网站打开被提示该内容被禁止访问的原因分析
|
Web App开发 缓存 网络协议
网页页面下各种标签的含义
1、charset: 2、X-UA-Compatible: 3、canonical : 4、dns-prefetch: 5、keywords 6、viewport 7、description
161 0
|
数据安全/隐私保护
标签打印软件中如何为标签文件设置密码
为了保护用标签打印软件制作的标签文件的安全性和隐私性,标签打印软件有一项对制作好的标签文件加密功能,类似文件加密一样,在打开标签的时候需要输入正确的标签密码才能打开标签。接下来就教大家在标签打印软件中如何设置标签密码。
1055 0
|
安全
如何查找网站漏洞文件任意查看漏洞详情与利用
在对网站程序代码的安全检测当中,网站文件任意查看漏洞在整个网站安全报告中属于比较高危的网站漏洞,一般网站里都会含有这种漏洞,尤其平台,商城,交互类的网站较多一些,像普通权限绕过漏洞,导致的就是可以查看到网站里的任何一个文件,甚至可以查看到网站的配置文件config.php conn.php等等。
1275 0