-
张瑶萱做前端码农最没技术含量?打脸从搞崩一台电脑开始(蓝屏)-拼客学院
作者: admin 发布: 2019-04-05 分类:全部文章 阅读: 217次
张瑶萱做前端码农最没技术含量?打脸从搞崩一台电脑开始(蓝屏)-拼客学院
张瑶萱
很多人都在说:“技术领域当中,前端最没有技术含量,且容易被替代。”有人说,前端的能力界限顶多就在浏览器那儿,无论你触发了多少bug,最多导致浏览器崩溃,连电脑系统都影响不了。
就像二次元各种炫酷的毁灭世界,都不会导致三次元的世界末日。
这我就不能忍了。作为一个前端,我发现还是有方式突破次元壁、打开次元大门的…
这个实验脑洞较大,动机无聊,但某种意义上反映了一些安全问题。
想象一下,有天你在家里上网,吃着火锅还唱着歌,点开一个链接,电脑突然就蓝屏了!想想还真有点小激动。
起因
故事得从localStorage(本地存储)说起。
html5的本地存储,相信大家都不陌生。将数据以二进制文件形式存储到本地,在当前应用得非常广泛。
windows下的chrome,localStorage存储于C:\Users\xxx\AppData\Local\Google\Chrome\User Data\Default\Local Storage文件夹中。但如果任由网页无限写文件,对用户硬盘的伤害可想而知,因而浏览器对其做了大小限制。
对于一个域名+端口,PC端的上限是5M-10M之间,移动端的则是不大于2.5M。
那么问题就变成:这样的限制足够保护用户硬盘了吗?
关键
关键的问题在于,这一限制,针对的是一个域名+端口。
也就是说,你访问同一个域名的不同端口,它们的localStorage并无关联,是分开存储的。
我用node简单地开启了服务器,这时,用户访问到这100个端口,会请求到同一个页面index.html。
当然,这个index.html里涉及了localStorage写操作。
我试着用浏览器分别访问了几个端口,结果是分开存储。一切跟剧本一样。
自动遍历
但这种程度还不够。
如果要让实验变得更好(xie)玩(e)一些,问题就变成如何让用户自动遍历这些端口?
iframe是个好的尝试。
只要一打开 1000,页面的脚本就会创建一个iframe,去请求 1001,一直循环下去。
当然iframe我们还可以设置为不可见,以掩盖这种不厚道的行为…
比方说,有人发给你一个链接,你打开后发现是个视频,而你根本注意不到背后的脚本,在视频播放的几分钟里,快要把你的C盘写满。
然后我就看到请求如潮水渐涨:
但是,请求到1081端口,最新的chrome就崩溃掉了…原来iframe嵌套太多,已经到达了浏览器的极限。
防止浏览器崩溃
C盘还未撑满,同志还需努力。怎么办?
突然想到,到达iframe极限之前,我们可以重定向啊。
每访问50个端口,就使用window.location.href重定向一次,去确保浏览器不崩溃。
事实证明,这种野蛮的方法的确可行。
至此,只要访问 1000,就会往Local Storage文件夹里写入近500M无用数据:
里面的数据是这样的:
继续实验的黑科技
算了下我的C盘还有空间嘛,那就把端口数量从100增长到200个。结果是这样的,到达了1.17G大小。
在后续的实验中,我就慢慢地把端口数量与存储的数据调大。
电脑也运行得越来越慢。这是为什么呢?
我观察到,有时候执行localStorage.setItem()后,在文件夹里不一定立即能看到数据文件。我怀疑这些数据会被chrome先放到内存里,以避免重复读写带来的消耗,在空闲或关闭的时机,再写进硬盘里。
但此时,浏览器已经影响到系统了。它处于一种“不会崩溃”,但“因为占用了许多内存,已经妨碍用户电脑的正常使用”的状态。
即使用户关闭了浏览器窗口,也不会很快恢复。要知道读写任务并不是随窗口关闭而终止的,否则浏览器会丢失数据。
遭遇黑科技的人们能做的只有:
等待;
用任务管理器关掉chrome进程,再等待;
相信并尝试“重启电脑解决90%电脑问题”的科学论断。
可以说,浏览器的内心几乎是崩溃的。
最后
最后,还是得用严肃脸告诫一下:害人之心不可有。
本实验,从一开始就是怀揣着将安全问题上交给国家的初衷去做的(是的就是这么纯粹)。
后续,看着C盘还有2G空间,我又把端口增长到2000个,试下会发生什么。
由于请求过多,需要一定时间,我就去做别的事情了。
回来后发现房间安静祥和,美轮美奂,一片蓝光,像是加了特技。
那么…
问题来了,计算机修理哪家强?
有点急…
链接:
作者:Litten
原标题:如何机智的弄坏一台电脑?来自一名前端工程师的报复...
推荐阅读
从一次溯源窥探地下YY直播洗号产业链
所谓“肉鸡”究竟是怎么成为肉鸡的?
安卓再曝漏洞又如何,难道要我们全换成苹果手机吗?
秒懂系列 | 史上最简单的Python Django入门教程
你的硬盘里,有没有想删的秘密?
[快递理赔诈骗]溯源分析,剁手党们都小心了!
Linux现新Bug,运维人你家产品中招了没?
又是「数据丢失」又是「挂掉宕机」,腾讯云运维工程师这口锅背定了?
几种主流编程语言的优点和缺点比较,不服来怼
为什么说,区块链的协议都很“胖”?
“懒惰”的 Linux 管理员都会的 10 个关键技巧
以Java工程师为例,技术面试应该怎么准备?
如何用一段简单的代码讲述一个悲伤的故事?
一行代码可以做什么?看到最后一个我终于忍不住了...
那些年你“听不懂”的安全名词
一个黑客的自白:你的摄像头是如何被攻击的
手把手|50行Python代码教你爬取猫眼电影TOP100榜所有信息
▼▼▼
[联系圈圈@拼客学院]
欢迎咨询课程详情!原创文章,转载请注明出处!标签:
相关日志:
- 2020-11-06 汽车检测与维修技术专业【视频】8月6日南京、苏州、常州、上海、杭州双卧七日夏令营2280元-陕西腾辉国旅
- 2020-11-06 广州市地税【视频】喀什市国税局打造南疆最大网上办税体验厅-喀什电视台
- 2020-11-06 汶川大地震电影【视频】8月12日(周六)特惠!游船玩转天马岛、乘索道赏大型史诗级历史大剧《天马忠魂》-苍山风行户外
- 2020-11-06 梦醒了简谱【视频】70后一定要听的30首歌找全了,快收藏-陳大會國學文化
- 2020-11-06 常州红星美凯龙【视频】唯老村长独活 千年老树砍下做棺材,引发万蛇倾巢而出,全村皆亡-老板谈创业
我不去想,是否能够成功,既然选择了远方,便只顾风雨兼程。 我不去想,能否赢得爱情,既然钟情于玫瑰,就勇敢地吐露真诚。 我不去想,身后会不会袭来寒风冷雨,既然目标是地平线,留给世界的只能是背影。 我不去想,未来是平坦还是泥泞,只要热爱生命, 一切,都在意料之中! |
- 文章归档
-
- 2020年11月 (60)
- 2020年10月 (313)
- 2020年9月 (302)
- 2020年8月 (317)
- 2020年7月 (312)
- 2020年6月 (294)
- 2020年5月 (325)
- 2020年4月 (302)
- 2020年3月 (321)
- 2020年2月 (286)
- 2020年1月 (311)
- 2019年12月 (313)
- 2019年11月 (214)
- 2019年10月 (240)
- 2019年9月 (292)
- 2019年8月 (223)
- 2019年7月 (92)
- 2019年6月 (84)
- 2019年5月 (97)
- 2019年4月 (1583)
- 2019年3月 (2194)
- 2019年2月 (360)
- 2019年1月 (386)
- 2018年12月 (206)
- 2018年11月 (306)
- 2018年10月 (328)
- 2018年9月 (291)
- 2018年8月 (312)
- 2018年7月 (311)
- 2018年6月 (294)
- 2018年5月 (318)
- 2018年4月 (302)
- 2018年3月 (317)
- 2018年2月 (282)
- 2018年1月 (324)
- 2017年12月 (326)
- 2017年11月 (300)
- 2017年10月 (319)
- 2017年9月 (299)
- 2017年8月 (303)
- 2017年7月 (149)
- 2017年6月 (86)
- 2017年5月 (98)
- 2017年4月 (81)
- 2017年3月 (97)
- 2017年2月 (86)
- 2017年1月 (90)
- 2016年12月 (107)
- 2016年11月 (101)
- 2016年10月 (101)
- 2016年9月 (84)
- 2016年8月 (92)
- 2016年7月 (94)
- 2016年6月 (92)
- 2016年5月 (108)
- 2016年4月 (90)
- 2016年3月 (92)
- 2016年2月 (85)
- 2016年1月 (93)
- 2015年12月 (102)
- 2015年11月 (98)
- 2015年10月 (92)
- 2015年9月 (84)
- 2015年8月 (91)
- 2015年7月 (86)
- 2015年6月 (97)
- 2015年5月 (92)
- 2015年4月 (81)
- 2015年3月 (94)
- 2015年2月 (81)
- 2015年1月 (90)
- 2014年12月 (102)
- 2014年11月 (95)
- 2014年10月 (92)
- 2014年9月 (100)
- 2014年8月 (101)
- 2014年7月 (90)
- 2014年6月 (106)
- 2014年5月 (99)
- 2014年4月 (65)