jQuery源码中的赌博网站
前言
jQuery源码中有赌博网站?
起因是公司发的一份自查文件,某银行在日常安全运营过程中发现在部分jQuery源码中存在赌博和黄色网站链接。
链接分为好几个:
- www.cactussoft.cn
- blindsignals.com
- www.planeart.cn/?p=877
如果你的代码中使用了jQuery或者间接使用了jQuery,请最好自查一下。
不要以为只有从网上随便抄来的jQuery源码才会存在这个问题,正常的jQuery源码也可能有,比如阿里的CDN上的jQuery源码中就有。
自查jQuery发现存在问题,追溯至阿里的CDN
在如今React和Vue,Angular占据前端主流的情况下,仍有大量的网站使用jQuery。
不过因为我现在做的项目比较新,并且使用React,所以以为这份自查文件跟我完全没关系。
只是因为以前见识过有人在开源js代码中埋挖矿的代码,所以谨慎起见还是查了查,没想到我还真的查出了点东西。
自查步骤:
- 第一步,我在代码中全局搜索上面三个网址,没发现问题,果然符合预期。
- 第二步,为了保险起见,我搜了node_modules里的文件,还是没有发现问题,符合预期。
- 第三步,全局搜索jQuery这个字符串,因为据自查文件描述这个问题主要存在于jQuery中。项目中除了single-spa源码对jQuery做了兼容处理,其他代码一切正常,没有引用jQuery的地方。
只是有个地方有点奇怪,我在一个奇怪的demo.html中,发现了下面这行引用:
<!-- jQuery -->
<script src="https://a1.alicdn.com/oss/uploads/2018/12/26/7bfddb60-08e8-11e9-9b04-53e73bb6408b.js"></script>
上面标注了一个jQuery,下面是一个阿里的CDN的地址。
那么这个引用里面是个jQuery?查一查吧。
打开这个js,搜索三个网址,最后真的找到了一个,代码如下:
// Based off of the plugin by Clint Helfers, with permission.
// http://blindsignals.com/index.php/2009/07/jquery-delay/
delay: function( time, type ) {
time = jQuery.fx ? jQuery.fx.speeds[ time ] || time : time;
type = type || "fx";
return this.queue( type, function( next, hooks ) {
var timeout = setTimeout( next, time );
hooks.stop = function() {
clearTimeout( timeout );
};
});
},
麻了,是个注释,但是这个网站真的存在,还是个中文站点呢。
这个网站虽然不是赌博网站,但是怎么看都不是那么正经,并且和jQuery完全没关系。
然后我又查了一下这个demo.html的来源,来自阿里的矢量图标库网站:https://www.iconfont.cn/,做前端的对这个站点应该非常熟悉。
然后这个demo.html就是下载个人项目的图标库后的演示用例。

正常情况下应该是用不到这个东西的,所以直接删掉就好了,不过阿里有没有别的地方用到这个CDN文件就不好说了。
思考
这次我们在阿里CDN上的jQuery库中都能发现赌博网站的链接。
虽然它是个注释,但是万一它不是呢?
毕竟这三个网址中可能就这个温和点,另外两个据描述直接重定向到黄色网站和赌博网站。
这个温和点的其实也没有那么温和,当这个jQuery文件被一些信誉度较高的站点,比如政府站点引用后,即使是注释里的网址可能也会被一些搜索引擎解析后用于提高这个垃圾网站的信誉度。
这个事情其实只是冰山一角而已,采用的方式虽然隐蔽但也总算有迹可循,之前爆出的js挖矿代码,更加隐蔽。
不谈这种引用外链的方式,对现在的前端而言,node_modules更是一个大黑盒。
主流的React这类库可能安全性还行,毕竟一天到晚读源码背八股文面试的朋友那么多,所以没什么问题。
像很多依赖库都是一两个人维护,就算他们不使坏,依赖库的依赖库呢?
这么庞大的依赖库链,实际上隐藏着的是巨大的安全隐患。
像上面提到的这个网站,你看链接里有个2009,可见这玩意并不年轻,一直默默地在每个jQuery网站中运行,并没有被人发现。
那么更多的这种代码是不是已经存在于各种各样的网站中了呢?
无脑复制粘贴的前端那么多,他们甚至都不愿意读一下自己复制的代码,更何况审查依赖库?
如果今天阿里这个CDN里面埋的是个挖矿代码,那么我们的讨论风格还会这么轻松有趣吗?
想了想,答案是:更加有趣了。O(∩_∩)O
jQuery源码中的赌博网站的更多相关文章
- Jquery源码中的Javascript基础知识(一)
jquery源码中涉及了大量原生js中的知识和概念,文章是我在学习两者的过程中进行的整理和总结,有不对的地方欢迎大家指正. 本文使用的jq版本为2.0.3,附上压缩和未压缩版本地址: http://a ...
- jquery源码中noConflict(防止$和jQuery的命名冲突)的实现原理
jquery源码中noConflict(防止$和jQuery的命名冲突)的实现原理 最近在看jquery源码分析的视频教学,希望将视频中学到的知识用博客记录下来,更希望对有同样对jquery源码有困惑 ...
- jQuery源码中的“new jQuery.fn.init()”什么意思?
所有文章搬运自我的个人主页:sheilasun.me 引子 最近打算试试看看jQuery的源码,刚开个头就卡住了.无论如何都理解不了jQuery源码入口部分中的 return new jQuery.f ...
- Jquery源码中的Javascript基础知识(三)
这篇主要说一下在源码中jquery对象是怎样设计实现的,下面是相关代码的简化版本: (function( window, undefined ) { // code 定义变量 jQuery = fun ...
- Jquery源码中的Javascript基础知识(二)
接上一篇,jquery源码的这种写法叫做匿名函数自执行 (function( window, undefined ) { // code })( window ); 函数定义了两个参数window和u ...
- 关于jQuery源码中(function(window,undefined){//dosomething()})(window)写法解释
一.首先是最常见的闭包 (Closure) 范式自执行函数的写法,这里用匿名函数封装(构造块级作用域),避免了匿名函数内部的代码与外部之间发生冲突(如使用了相同的变量名). (function() { ...
- jQuery 源码中的 camelCase
先看一下源码 //65-72行 // Matches dashed string for camelizing //匹配连字符 ‘-’ 和其后的第一个字母或数字,如果是字母,则替换为大写,如果是数字, ...
- jquery源码中的(function(window, undefined){})(window)【转】
(function( window, undefined ) {})(window);这个,为什么要将window和undefined作为参数传给它? (function( $, undefined ...
- Jquery源码中的Javascript基础知识(四)— jQuery.fn.init方法
$() 即调用了jQuery.fn.init方法 jQuery = function( selector, context ) { return new jQuery.fn.init( selecto ...
随机推荐
- IEEE 754 浮点数加减运算
电子科技大学 - 计算机组成原理 小数的十进制和二进制转换 移码 定义:[X]移 = X + 2n ( -2n ≤ X < 2n ) X为真值,n为整数的位数 数值位和X的补码相同,符号位与补码 ...
- 初学python-day3 列表
- Java:并发笔记-01
Java:并发笔记-01 说明:这是看了 bilibili 上 黑马程序员 的课程 java并发编程 后做的笔记 1. 进程与线程 本章内容 进程和线程的概念 并行和并发的概念 线程基本应用 1.1 ...
- Prometheus重新标记
Prometheus重新标记 一.背景 二.简化的指标抓取的生命周期 1.配置参数详解 1.`action:`存在的值 1.替换标签值 2.删除指标 3.创建或删除标签 2.删除标签注意事项 3.几个 ...
- poi实现生成下拉选
在我们日常开发中,经常需要使用poi操作excel文件,现在就简单介绍一下在poi中是如何生成下拉选的. 1.创建workbook 2.创建数据约束 3.设置数据的有效性 @Test public v ...
- [ NOIP2013 D2-T3 ] 华容道
NOIP2013 华容道 图论好题. 介于网上全是些令蒟蒻头昏的题解和排版一塌糊涂以及过于详细的题解...蒟蒻记录一下.. 显然需要将白格移动到 \(s\) 相邻格,然后交换 \(s\) 与白格,再将 ...
- openmp学习心得(一)
主要在vs2015下使用OMP,写一些自己omp的学习心得: 一.在VS2015下OpenMP的使用: 1.VS2015也仅仅支持OpenMP2.0版本,VS对OpenMP的支持并不太好. 2.在VS ...
- Spring---IoC(控制反转)原理学习笔记【全】
1.IoC创建对象的方式 使用无参构造创建对象 假如要使用有参构造创建: 下标赋值constructor-arg <!--有参--> <bean id="User" ...
- Android DataBinding使用详解
简介 DataBinding是一个自动绑定UI的框架. 使用DataBinding需要在app根目录的build.gradle文件中加入DataBinding配置: android { .... da ...
- Ubuntu virtualenv 创建 python3 虚拟环境 激活 退出
首先默认安装了virtualenv 创建python3虚拟环境 your-name@node-name:~/virtual_env$ virtualenv -p /usr/bin/python3 py ...