[]()+! 实现JavaScript代码的原理
2010-02-28 12:08
495 查看
昨天转载了这篇 博文,介绍了这个比较特别的JavaScript实现方式,很多同学留言说看不懂,我就给大家简单分析一下。其实就是利用了JavaScript的简单原理。
首先分析一下这几个字符都是什么东西:
! = false
[] = 数组
+ = 连接符
() = 对象分隔符
然后怎么实现各种JavaScript代码呢?比如说我们要打一个a,要怎么做呢?
很简单: (![]+[])[1] ,明白了吧。也就是相当于"false”[1], 取false字符串的第二个字符。
那又要有同学问了,怎么输入1呢?false里面也没有1呀?
那我们首先要知道怎么表示true,有了false怎么表示true呢?
更简单了: !+[] 。
然后大家就明白了把,true=1.
那。。2怎么表示呢?。。。当然就是true+true了,也就是!+[]+!+[]
然后又有同学问了,那有些字符不在true或者false里面怎么办呢?
大家就可以参考之前那篇介绍中的码表,一一对应。
其实这个主要还是利用了JavaScript里面灵活多变的表达方式,对基本功要求比较高,要明白各种字符在各种类型转换下的值具体是多少,然后拼接组合出来。
这个技术嘛。。感觉也就是挂马用吧。。。想不出其他还有什么用处。
首先分析一下这几个字符都是什么东西:
! = false
[] = 数组
+ = 连接符
() = 对象分隔符
然后怎么实现各种JavaScript代码呢?比如说我们要打一个a,要怎么做呢?
很简单: (![]+[])[1] ,明白了吧。也就是相当于"false”[1], 取false字符串的第二个字符。
那又要有同学问了,怎么输入1呢?false里面也没有1呀?
那我们首先要知道怎么表示true,有了false怎么表示true呢?
更简单了: !+[] 。
然后大家就明白了把,true=1.
那。。2怎么表示呢?。。。当然就是true+true了,也就是!+[]+!+[]
然后又有同学问了,那有些字符不在true或者false里面怎么办呢?
大家就可以参考之前那篇介绍中的码表,一一对应。
其实这个主要还是利用了JavaScript里面灵活多变的表达方式,对基本功要求比较高,要明白各种字符在各种类型转换下的值具体是多少,然后拼接组合出来。
这个技术嘛。。感觉也就是挂马用吧。。。想不出其他还有什么用处。
相关文章推荐
- javascript圆盘抽奖程序实现原理和完整代码例子
- 在ASP.NET使用JavaScript显示信息提示窗口实现原理及代码
- js/ajax跨越访问-jsonp的原理和实例(javascript和jquery实现代码)
- js/ajax跨越访问-jsonp的原理和实例(javascript和jquery实现代码)
- 中文前端UI框架Kit(六)javascript动画代码实现原理和一些小技巧
- 在ASP.NET使用JavaScript显示信息提示窗口实现原理及代码
- js/ajax跨越访问-jsonp的原理和实例(javascript和jquery实现代码)
- javascript圆盘抽奖程序实现原理和完整代码例子
- JavaScript实现自己的DOM选择器原理及代码
- JavaScript如何控制Session实现原理及代码
- javascript实现代码高亮原理
- 深入浅出编译原理-6-一个完整的编译器前端的代码实现
- javascript实现标签切换代码示例
- 归并排序的原理,c++代码实现
- javascript实现自动跳转到首页的代码实例
- Javascript实现代码折叠功能
- javascript实现youku的视频代码自适应宽度