解析JavaScript实现DDoS攻击原理与保护措施


Posted in Javascript onDecember 26, 2016

DDos介绍

最普遍的攻击是对网站进行分布式拒绝服务(DDoS)攻击。在一个典型的DDoS攻击中,攻击者通过发送大量的数据到服务器,占用服务资源。从而达到阻止其他用户的访问。

如果黑客使用JavaScript的DDoS攻击,那么任何一台计算机都可能成为肉鸡,使潜在的攻击量几乎是无限的。

Javascript实现DDos攻击原理分析

现在网站的交互性都是通过JavaScript来实现的。通过添加JavaScript直接插入HTML元素,或通过远程来加载JavaScript。浏览器会读取script标签中的src属性并运行它所指向的脚本,其实不只是script标签可以用来攻击,简单来说只要是可以跨域访问的标签,如img,link等都可以实现DDos攻击。

既然这些标签可以访问外站的资源,那么我们是不是就可以设个定时器无限访问这个网站,从而达到攻击呢,那是肯定的。

最终DDos攻击手法

如果只是一台电脑进行攻击,那也造不成什么危害,除非是对方网站根本没有对网站进行安全保护,现在大部分网站都有用CDN来隐藏真实的ip,并且这些网站大部分也有防DDos攻击,很多网站也会设置网站黑名单,如果一台计算机在一段时间内不断访问的话,那么就很有可能被加入黑名单。那么难道就没有办法了吗。

自然不是,只要你开放网站,黑客就有办法攻击,当然也要看那个黑客的技术了。

现在的网站几乎都使用了JavaScript的库。为了节省带宽,提高性能,很多网站都通过第三方的网站托管服务,来加载这些js库。如果这些第三方网站的js库中存在恶意代码的话,很有可能被利用,一些牛逼的黑客可以通过破解这些第三方网站的后台,修改脚本。如果用户访问这个网站的话就会下载这些脚本并执行,这些用户的计算机就会变成肉鸡,如果这个网站访问量比较大的话,那么就。。。

简单来说就是通过访问量较大的网站攻击目标网站。

保护措施

为了解决这个问题,W3C提出了一个新的功能叫做子资源的完整性,你可以告诉浏览器如果它不符合你期望的运行脚本,通过使用加密哈希。它就像一个指纹:只有两个文件具有相同的哈希,那么才能被匹配,当用户的计算机下载这些脚本后,浏览器会计算其哈希,如果与预期的不匹配,那么就说明这些脚本已经被篡改,浏览器将不会执行这个脚本。

原先我们是这样引用脚本的

<script src="http://www.xxx.com/xxx.js"></script>

现在的做法

<script src="http://www.xxx.com/xxx.js" integrity="sha384-hK8q2gkBjirpIGHAH+sgqYMv6i6mfx2JVZWJ50jyYhkuEHASU6AS1UTWSo32wuGL" crossorigin="anonymous"><br><br>integrity:哈希值<br>crossorigin:是为了保证浏览器的同源策略的正确实施,防止跨站脚本(XSS)攻击<br><br>生成哈希值的网站:www.srihash.org

以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,同时也希望多多支持三水点靠木!

Javascript 相关文章推荐
JavaScript 不只是脚本
May 30 Javascript
javascript 动态加载 css 方法总结
Jul 11 Javascript
再谈ie和firefox下的document.all属性
Oct 21 Javascript
js常用代码段收集
Oct 28 Javascript
FF火狐下获取一个元素同类型的相邻元素实现代码
Dec 15 Javascript
jQuery中:radio选择器用法实例
Jan 03 Javascript
JavaScript实现跑马灯抽奖活动实例代码解析与优化(二)
Feb 16 Javascript
Javascript基础_标记文字的实现方法
Jun 14 Javascript
微信小程序 实现列表项滑动显示删除按钮的功能
Apr 13 Javascript
jQuery实现点击DIV同时点击CheckBox,并为DIV上背景色的实例
Dec 18 jQuery
Vue实现内部组件轮播切换效果的示例代码
Apr 07 Javascript
JS使用正则表达式获取小括号、中括号及花括号内容的方法示例
Jun 01 Javascript
JS实现密码框的显示密码和隐藏密码功能示例
Dec 26 #Javascript
原生JS下拉加载插件分享
Dec 26 #Javascript
jQuery实现的checkbox级联选择下拉菜单效果示例
Dec 26 #Javascript
javascript输出AscII码扩展集中的字符方法
Dec 26 #Javascript
在一个页面重复使用一个js函数的方法详解
Dec 26 #Javascript
jquery无法为动态生成的元素添加点击事件的解决方法(推荐)
Dec 26 #Javascript
jQuery实现动态添加tr到table的方法
Dec 26 #Javascript
You might like
VOLVO车载收音机
2021/03/02 无线电
坏狼的PHP学习教程之第1天
2008/06/15 PHP
php中hashtable实现示例分享
2014/02/13 PHP
php实现用手机关闭计算机(电脑)的方法
2015/04/22 PHP
php简单截取字符串代码示例
2016/10/19 PHP
PHP操作Postgresql封装类与应用完整实例
2018/04/24 PHP
javascript CSS画图之基础篇
2009/07/29 Javascript
简单的前端js+ajax 购物车框架(入门篇)
2011/10/29 Javascript
Javascript 异步加载详解(浏览器在javascript的加载方式)
2012/05/20 Javascript
JS两种类型的表单提交方法实例分析
2016/11/28 Javascript
jQuery图片轮播实现并封装(一)
2016/12/03 Javascript
用jQuery.ajaxSetup实现对请求和响应数据的过滤
2016/12/20 Javascript
Javascript中类式继承和原型式继承的实现方法和区别之处
2017/04/25 Javascript
vue跨域解决方法
2017/10/15 Javascript
nodejs使用async模块同步执行的方法
2019/03/02 NodeJs
Python实现的石头剪子布代码分享
2014/08/22 Python
介绍Python的Django框架中的QuerySets
2015/04/20 Python
详解Python的Django框架中的templates设置
2015/05/11 Python
Python3处理文件中每个词的方法
2015/05/22 Python
Python 3.x 新特性及10大变化
2015/06/12 Python
Python中模块pymysql查询结果后如何获取字段列表
2017/06/05 Python
基于Python的关键字监控及告警
2017/07/06 Python
python控制windows剪贴板,向剪贴板中写入图片的实例
2018/05/31 Python
Numpy中矩阵matrix读取一列的方法及数组和矩阵的相互转换实例
2018/07/02 Python
python3.6使用urllib完成下载的实例
2018/12/19 Python
Django如何简单快速实现PUT、DELETE方法
2019/07/24 Python
TensorFlow dataset.shuffle、batch、repeat的使用详解
2020/01/21 Python
python多进程使用函数封装实例
2020/05/02 Python
Django ModelForm组件原理及用法详解
2020/10/12 Python
Numpy中的数组搜索中np.where方法详细介绍
2021/01/08 Python
多媒体专业自我鉴定
2014/02/28 职场文书
法律专业求职信
2014/05/24 职场文书
学校教师读书活动总结
2014/07/08 职场文书
商业企业管理专业求职信
2014/07/10 职场文书
工作证明格式及范本
2014/09/12 职场文书
2014年学校党建工作总结
2014/11/11 职场文书