[]()+! 实现JavaScript代码的原理

昨天转载了这篇 博文,介绍了这个比较特别的JavaScript实现方式,很多同学留言说看不懂,我就给大家简单分析一下。其实就是利用了JavaScript的简单原理。

首先分析一下这几个字符都是什么东西:

! = false

[] = 数组

+ = 连接符

() = 对象分隔符

 

然后怎么实现各种JavaScript代码呢?比如说我们要打一个a,要怎么做呢?

很简单: (![]+[])[1] ,明白了吧。也就是相当于"false”[1], 取false字符串的第二个字符。

 

那又要有同学问了,怎么输入1呢?false里面也没有1呀?

那我们首先要知道怎么表示true,有了false怎么表示true呢?

更简单了: !+[] 。

然后大家就明白了把,true=1.

那。。2怎么表示呢?。。。当然就是true+true了,也就是!+[]+!+[]

 

然后又有同学问了,那有些字符不在true或者false里面怎么办呢?

大家就可以参考之前那篇介绍中的码表,一一对应。

 

其实这个主要还是利用了JavaScript里面灵活多变的表达方式,对基本功要求比较高,要明白各种字符在各种类型转换下的值具体是多少,然后拼接组合出来。

 

这个技术嘛。。感觉也就是挂马用吧。。。想不出其他还有什么用处。

posted on 2010-02-28 12:08  Pandora  阅读(1942)  评论(5编辑  收藏  举报

导航