[经验分享]又见卡死图,竟然一个“小黑点”就能干掉QQ?--转载FreeBuf

正序

前一阵子QQ群里流行了一个东西,一段话加上一个黑点(表情),点击之后QQ就会卡死。

0

当时只觉得很好玩,没多久就又见了一次。

0

既然又看到了就一定要好好看看了。

刚开始遇到这个时第一反应是曾经看过的文章《一张GIF引发的微信崩溃》,所以第一反应也是扔进010Editor看看,然而并没有什么异常的地方。就在这时无意间看到了图片的名字,觉得不一般,后想了想会不会是和“十五个句号”一样触发了什么东西。

表情图片名称:

0
0
0

最后看了看实在想不到有什么异常的。虽然名字奇怪了点但一般这种图片不都是这样吗。更何况都有后缀名结尾,应该是翻不起什么浪的。这一会的我怕是已经有点草木皆兵了。

如果不是图片的话那么就是文字的原因喽?文字复制~

0

浏览器顺利爆炸:

0

地址栏里好像有什么东西。经过精简最后拿到了:%E2%80%8E

浏览器中重复出现这个东西:

0

到这里真相就差不多了,N多个%E2%80%8E循环出现。那么这个%E2%80%8E到底是什么呢个?经过查阅资料这东西叫ZERO-WIDTH SPACE,顾名思义0宽度,所以这东西看不见。那么既然是“隐形”的那它隐藏了什么?编码转换后得到如下:

0

我们可以看出这三个起来作用“‎‏‫”

‎LRM‎ 从左到右标记

‏RLM从右向左标记

‫RLE‫ 开始从右向左嵌入

到这里就可以看出了,其实&#8235也是可以去掉的,真正生效的是LRM和RLM。多个左右标记循环出现,当用户去指定一个位置时会因为“反复横跳”导致当前程序崩溃。而原来的黑点以及国旗只是给用户错觉,让人以为是它的原因。而“‎‏‫”重复出现应该也只是制造者为了尽量卡死用户而特意重复书写,并不是因为某种原因而生成的。理论上来说这个对所有触屏手机和其运行的软件能够生效。(如果点一次没卡可以多作几次,iOS未测试)。

那么既然知道了原理我们也可以制作一个自己的“卡死图”。

格式基本为:(‎‏)*N+图片或文字

然后将(‎‏)*N由unicode转换为ASCII,得到的即为只显示文字或图片的“卡死图”。

番外

一个特殊的字符?(%E2%80%8B)

Left​​​​​​​​​​Right

把上面的两个单词拷贝下来,粘贴到一个文本编辑器中,比如txt文件。尝试在字符串中移动光标,会发现在t和R之间要移动3次才能移动过去,也就是说,其实那儿有一个特殊的字符,它没有宽度,让人误以为是什么也没有,但是如果编码一下会发现确实是有东西的:
encodeURI():%E2%80%8B

感觉能弄来做点有意思的事。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值