解析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 Array对象基础知识小结
Nov 16 Javascript
js获取事件源及触发该事件的对象
Oct 24 Javascript
简单讲解AngularJS的Routing路由的定义与使用
Mar 05 Javascript
Bootstrap嵌入jqGrid,使你的table牛逼起来
May 05 Javascript
jQuery中的insertBefore(),insertAfter(),after(),before()区别介绍
Sep 01 Javascript
基于vue监听滚动事件实现锚点链接平滑滚动的方法
Jan 17 Javascript
js遍历添加栏目类添加css 再点击其它删除css【推荐】
Jun 12 Javascript
vue+iview 兼容IE11浏览器的实现方法
Jan 07 Javascript
详解项目升级到vue-cli3的正确姿势
Jan 28 Javascript
微信小程序实现用table显示数据库反馈的多条数据功能示例
May 07 Javascript
js实现滑动滑块验证登录
Jul 24 Javascript
javascript实现京东登录显示隐藏密码
Aug 02 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
Yii基于数组和对象的Model查询技巧实例详解
2015/12/28 PHP
PHP mysql事务问题实例分析
2016/01/18 PHP
项目中应用Redis+Php的场景
2016/05/22 PHP
PHP三种方式实现链式操作详解
2017/01/21 PHP
JQuery 学习笔记 选择器之五
2009/07/23 Javascript
Jquery 表单验证类介绍与实例
2013/06/09 Javascript
js编码、解码函数介绍及其使用示例
2013/09/05 Javascript
JS中把字符转成ASCII值的函数示例代码
2013/11/21 Javascript
js操作输入框中选择内容兼容IE及其他主流浏览器
2014/04/22 Javascript
js获取网页可见区域、正文以及屏幕分辨率的高度
2014/05/15 Javascript
CascadeView级联组件实现思路详解(分离思想和单链表)
2016/04/12 Javascript
Bootstrap中的fileinput 多图片上传及编辑功能
2016/09/05 Javascript
微信小程序 UI布局常用技巧整理总结
2016/12/05 Javascript
JavaScript判断浏览器及其版本信息
2017/01/20 Javascript
Vue2.0仿饿了么webapp单页面应用详细步骤
2018/07/08 Javascript
Vue-cli3简单使用(图文步骤)
2019/04/30 Javascript
详解微信小程序自定义组件的实现及数据交互
2019/07/22 Javascript
Jquery Datatables的使用详解
2020/01/30 jQuery
ES5 模拟 ES6 的 Symbol 实现私有成员功能示例
2020/05/06 Javascript
如何使用JS console.log()技巧提高工作效率
2020/10/14 Javascript
详解Python中的序列化与反序列化的使用
2015/06/30 Python
Python打造出适合自己的定制化Eclipse IDE
2016/03/02 Python
Python中json格式数据的编码与解码方法详解
2016/07/01 Python
python对离散变量的one-hot编码方法
2018/07/11 Python
对Tensorflow中的变量初始化函数详解
2018/07/27 Python
selenium获取当前页面的url、源码、title的方法
2019/06/12 Python
django ManyToManyField多对多关系的实例详解
2019/08/09 Python
Python一键查找iOS项目中未使用的图片、音频、视频资源
2019/08/12 Python
Python 没有main函数的原因
2020/07/10 Python
YSL圣罗兰美妆美国官网:Yves Saint Lauret US
2016/11/21 全球购物
枚举与#define宏的区别
2014/04/30 面试题
会计顶岗实习心得
2014/01/25 职场文书
初中体育教学随笔
2015/08/15 职场文书
golang 接口嵌套实现复用的操作
2021/04/29 Golang
使用Redis实现点赞取消点赞的详细代码
2022/03/20 Redis
MySQL分区表管理命令汇总
2022/03/21 MySQL