解析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 相关文章推荐
获取Javscript执行函数名称的方法
Dec 22 Javascript
百度 popup.js 完美修正版非常的不错 脚本之家推荐
Apr 17 Javascript
jQuery遍历json中多个map的方法
Feb 12 Javascript
javascript实时显示当天日期的方法
May 20 Javascript
JS for循环中i++ 和 ++i的区别介绍
Jul 20 Javascript
Javascript 创建类并动态添加属性及方法的简单实现
Oct 20 Javascript
jQuery的$.extend 浅拷贝与深拷贝
Mar 08 Javascript
JavaScript实现的选择排序算法实例分析
Apr 14 Javascript
JS基于贪心算法解决背包问题示例
Nov 27 Javascript
Vue2.0仿饿了么webapp单页面应用详细步骤
Jul 08 Javascript
解决jquery有正确返回值但不执行success函数的问题
Aug 20 jQuery
JavaScript中import用法总结
Jan 20 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
php仿ZOL分页类代码
2008/10/02 PHP
php实现对象克隆的方法
2015/06/20 PHP
基于PHP+jQuery+MySql实现红蓝(顶踩)投票代码
2015/08/25 PHP
javaScript对象和属性的创建方法
2007/01/15 Javascript
斜45度寻路实现函数
2009/08/20 Javascript
Javascript 实用小技巧
2010/04/07 Javascript
jQuery的链式调用浅析
2010/12/03 Javascript
ajax的hide隐藏问题解决方法
2012/12/11 Javascript
JavaScript实现统计文本框Textarea字数增强用户体验
2012/12/21 Javascript
关于textarea提交的内容无法换行的解决办法
2013/04/09 Javascript
ajax如何实现页面局部跳转与结果返回
2015/08/24 Javascript
bootstrap学习笔记之初识bootstrap
2016/06/21 Javascript
基于原生js淡入淡出函数封装(兼容IE)
2016/10/20 Javascript
jQuery绑定事件的四种方式介绍
2016/10/31 Javascript
使用jQuery实现一个类似GridView的编辑,更新,取消和删除的功能
2017/03/15 Javascript
JS ES6中setTimeout函数的执行上下文示例
2017/04/27 Javascript
基于 Vue 的树形选择组件的示例代码
2017/08/18 Javascript
利用Vue构造器创建Form组件的通用解决方法
2018/12/03 Javascript
Python列表(list)常用操作方法小结
2015/02/02 Python
Python使用Matplotlib实现雨点图动画效果的方法
2017/12/23 Python
python中多个装饰器的调用顺序详解
2019/07/16 Python
python list转置和前后反转的例子
2019/08/26 Python
使用Python下载抖音各大V视频的思路详解
2021/02/06 Python
python 三种方法提取pdf中的图片
2021/02/07 Python
梅西酒窖:Macy’s Wine Cellar
2018/01/07 全球购物
体育教育个人自荐信范文
2013/12/01 职场文书
个人教师自我评价范文
2013/12/02 职场文书
追悼会上的答谢词
2014/01/10 职场文书
出生公证委托书
2014/04/03 职场文书
电子信息专业应届生自荐信
2014/06/04 职场文书
车辆工程专业求职信
2014/06/14 职场文书
中学学校门卫岗位职责
2014/08/15 职场文书
公务员上班玩游戏检讨书
2014/09/17 职场文书
党的群众路线教育实践活动学习笔记范文
2014/11/06 职场文书
pytorch 如何把图像数据集进行划分成train,test和val
2021/05/31 Python
python中pymysql包操作数据库方法
2022/04/19 Python