JavaScript是一种松散类型的语言,它可以:
true+true == 2
可以不使用数字字面量来获取数字。+
符号 可以将对象类型转为字符串类型''+{} == '[object Object]'
[object Object][1] == 'o'
'abc'[0] == 'a'
以上,我们完全可以不使用数字和字母字面量来写一些js代码!
获取数字 0
比较简单,+[]
即为 0
;
为了获取数字 1
就需要使用 !
,+!![] == 1
或 +!+[]
等都为 1
。
要获取除 0
1
之外的数字,只需要使用加法即可。2 = 1 + 1
(废话) 即:+!+[]+!+[]
。
如果要是获取字母该如何?
其实有个技巧,我们可以利用js的特点,在某些情况下js或默认调用 toString()
或 valueOf()
函数,我们可以利用其获取字母。
例如,可以利用数组下标越界来获取类型 undefined
,然后将其隐式转换为字符串 'undefined'
,这样的话,我们就可以获取到 u
n
d
e
f
等字母!
看下面例子:
// 获取 'f'
console.log([[][+!+[]]+[]][+[]][+!+[]+!+[]+!+[]+!+[]]) // 'f'
解析:
[]
[][+!+[]]
,因为为空,所以会返回 undefined
+
上一个''
时会将其转换为字符串:[][+!+[]]+[]
,得到字符串 'undefined'
[+[]]
读取第0个位置,即 undefined
;方面后续取下标f
,需要读取字符串下标为 4
的位置:[[][+!+[]]+[]][+[]][+!+[]+!+[]+!+[]+!+[]]
这里我们只使用三种符号 []
+
!
即可表示字符 f
,amazing!
有了以上的铺垫,现在我们可以做一些不可思议的事情:
例如,调用 slice()
函数
let _slice = [][[![]+[]][+[]][!+[]+!+[]+!+[]]+[![]+[]][+[]][!+[]+!+[]]+[[][+!+[]]+[]][+[]][+!+[]+!+[]+!+[]+!+[]+!+[]]+ [[[]+[]][+[]]+{}][+[]][+!+[]+!+[]+!+[]+!+[]+!+[]]+[![]+[]][+[]][!+[]+!+[]+!+[]+!+[]]] // ƒ slice() { [native code] }// 测试
let arr = [1,2,3,4];
console.log(_slice.call(arr, 2)) // [ 3, 4 ]
访问Function构造函数:
[][[[][[[][[]]+[]][+[]][!+[]+!+[]+!+[]+!+[]]+[[][[]]+[]][+[]][!+[]+!+[]+!+[]+!+[]+!+[]]+[[][[]]+[]][+[]][!+[]+!+[]+!+[]+!+[]+!+[]+!+[]]+[[][[]]+[]][+[]][!+[]+!+[]]]+[]][+[]][!+[]+!+[]+!+[]]+[[]+{}][+[]][+!+[]]+[[][[]]+[]][+[]][!+[]+!+[]+!+[]+!+[]+!+[]+!+[]]+[![]+[]][+[]][!+[]+!+[]+!+[]]+[!![]+[]][+[]][+[]]+[!![]+[]][+[]][+!+[]]+[[][[]]+[]][+[]][+[]]+[[][[[][[]]+[]][+[]][!+[]+!+[]+!+[]+!+[]]+[[][[]]+[]][+[]][!+[]+!+[]+!+[]+!+[]+!+[]]+[[][[]]+[]][+[]][!+[]+!+[]+!+[]+!+[]+!+[]+!+[]]+[[][[]]+[]][+[]][!+[]+!+[]]]+[]][+[]][!+[]+!+[]+!+[]]+[!![]+[]][+[]][+[]]+[[]+{}][+[]][+!+[]]+[!![]+[]][+[]][+!+[]]][[[][[[][[]]+[]][+[]][!+[]+!+[]+!+[]+!+[]]+[[][[]]+[]][+[]][!+[]+!+[]+!+[]+!+[]+!+[]]+[[][[]]+[]][+[]][!+[]+!+[]+!+[]+!+[]+!+[]+!+[]]+[[][[]]+[]][+[]][!+[]+!+[]]]+[]][+[]][!+[]+!+[]+!+[]]+[[]+{}][+[]][+!+[]]+[[][[]]+[]][+[]][!+[]+!+[]+!+[]+!+[]+!+[]+!+[]]+[![]+[]][+[]][!+[]+!+[]+!+[]]+[!![]+[]][+[]][+[]]+[!![]+[]][+[]][+!+[]]+[[][[]]+[]][+[]][+[]]+[[][[[][[]]+[]][+[]][!+[]+!+[]+!+[]+!+[]]+[[][[]]+[]][+[]][!+[]+!+[]+!+[]+!+[]+!+[]]+[[][[]]+[]][+[]][!+[]+!+[]+!+[]+!+[]+!+[]+!+[]]+[[][[]]+[]][+[]][!+[]+!+[]]]+[]][+[]][!+[]+!+[]+!+[]]+[!![]+[]][+[]][+[]]+[[]+{}][+[]][+!+[]]+[!![]+[]][+[]][+!+[]]]
// ƒ Function() { [native code] }
上一篇:金融监管总局辽宁监管局:探索普惠理财形式,开拓普惠保险市场 金融监管总局辽宁 金融监管总局:提升保险保障能力
下一篇:V观财报|停牌18个月,东正金融被取消上市地位,4月29日除牌 V观财报|停牌18个月,东正金融被取消上市地位,4月29日除牌