解析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如何给&amp;lt;textarea&amp;gt;&amp;lt;/textarea&amp;gt;赋值
Apr 20 Javascript
JS根据变量保存方法名并执行方法示例
Apr 04 Javascript
jquery实现点击其他区域时隐藏下拉div和遮罩层的方法
Dec 23 Javascript
json对象与数组以及转换成js对象的简单实现方法
Jun 24 Javascript
Bootstrap基本组件学习笔记之input输入框组(9)
Dec 07 Javascript
浅谈javascript中的数据类型转换
Dec 27 Javascript
BootstrapTable请求数据时设置超时(timeout)的方法
Jan 22 Javascript
基于JS实现二维码图片固定在右下角某处并跟随滚动条滚动
Feb 08 Javascript
Vue实现动态显示textarea剩余字数
May 22 Javascript
灵活使用console让js调试更简单的方法步骤
Apr 23 Javascript
用JS实现一个简单的打砖块游戏
Dec 11 Javascript
Vue实现tab导航栏并支持左右滑动功能
Jun 28 Vue.js
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
桌面中心(四)数据显示
2006/10/09 PHP
php 数组的合并、拆分、区别取值函数集
2010/02/15 PHP
php对象和数组相互转换的方法
2015/05/12 PHP
PHP实现按之字形顺序打印二叉树的方法
2018/01/16 PHP
PHP开发之用微信远程遥控服务器
2018/01/25 PHP
jquery插件unobtrusive实现片段式加载
2015/06/15 Javascript
理解javascript中的原型和原型链
2015/07/30 Javascript
基于jQuery实现的美观星级评论打分组件代码
2015/10/30 Javascript
JavaScript ES5标准中新增的Array方法
2016/06/28 Javascript
js style.display=block显示布局错乱问题的解决方法
2016/09/21 Javascript
实现easyui的datagrid导出为excel的示例代码
2016/11/10 Javascript
jQuery实现圣诞节礼物动画案例解析
2016/12/25 Javascript
Bootstrap源码解读标签、徽章、缩略图和警示框(8)
2016/12/26 Javascript
Javascript 编码约定(编码规范)
2018/03/11 Javascript
基于elementUI实现图片预览组件的示例代码
2019/03/31 Javascript
js判断鼠标移入移出方向的方法
2020/06/24 Javascript
JS实现炫酷轮播图
2020/11/15 Javascript
js实现简单的倒计时
2021/01/28 Javascript
Python使用代理抓取网站图片(多线程)
2014/03/14 Python
Python3安装Pymongo详细步骤
2017/05/26 Python
python socket网络编程之粘包问题详解
2018/04/28 Python
python 3.74 运行import numpy as np 报错lib\site-packages\numpy\__init__.py
2019/10/06 Python
pytorch如何冻结某层参数的实现
2020/01/10 Python
python GUI库图形界面开发之PyQt5多行文本框控件QTextEdit详细使用方法实例
2020/02/28 Python
pycharm工具连接mysql数据库失败问题
2020/04/01 Python
解决python执行较大excel文件openpyxl慢问题
2020/05/15 Python
使用openCV去除文字中乱入的线条实例
2020/06/02 Python
Python数据模型与Python对象模型的相关总结
2021/01/26 Python
2014学年自我鉴定
2014/02/23 职场文书
机械设计制造及其自动化专业求职信
2014/06/17 职场文书
小学生我的梦想演讲稿
2014/08/21 职场文书
小学教师师德师风个人整改措施
2014/09/18 职场文书
党员思想汇报材料
2014/12/19 职场文书
golang slice元素去重操作
2021/04/30 Golang
开发微信小程序之WXSS样式教程
2022/04/18 HTML / CSS
MySQL事务的ACID特性以及并发问题方案
2022/07/15 MySQL