关于一道JS题目

JS变量作用域解析

请回答

var tt = 'aa';
function test(){
alert(tt);
var tt = 'dd';
alert(tt);
}
test();  

情后两次alert的结果。


原贴地址:http://topic.youkuaiyun.com/u/20120830/13/db72bec5-db6c-4c78-83ab-973f20bc2216.html?seed=228849005&r=79561154#r_79561154


我的总结:当在一个函数内部访问一个变量的时候,若在函数内部有定义该变量,无论其处于函数内部的什么位置,JS都会认为已经找到了该变量的定义,因此不再往上找,如不再往全局域找。但变量的定义只有在执行了定义语句之后才定义好。所以前面的题目第一个alert(tt)时,JS在函数内部找了该变量的定义,但未赋值,所以是undefined,第二个因定义好 了,所以是dd;

很遗憾,给定的参考引用中未包含BUUCTF平台的Javascript.Encode解密题目相关内容。不过一般在BUUCTF平台上这类题目可能会给出一段经过JavaScript编码混淆的代码,要求还原出原始代码逻辑或者提取出关键信息。 以下是一个模拟的类似场景题目示例: 在BUUCTF的某道题目中,给出了一段经过JavaScript编码混淆的代码如下: ```javascript var _0x1892=['\x61\x6C\x65\x72\x74','\x68\x65\x6C\x6C\x6F\x20\x77\x6F\x72\x6C\x64'];function _0x3918(_0x4993){return _0x1892[_0x4993];}(function(_0x1996,_0x4993){var _0x3918e=_0x3918;while(!![]){try{var _0x1696=-parseInt(_0x3918e(0))/0x1*(parseInt(_0x3918e(1))/0x2)+-parseInt(_0x3918e(0))/0x3*(parseInt(_0x3918e(1))/0x4)+parseInt(_0x3918e(0))/0x5*(parseInt(_0x3918e(1))/0x6)+parseInt(_0x3918e(0))/0x7*(parseInt(_0x3918e(1))/0x8)+-parseInt(_0x3918e(0))/0x9*(parseInt(_0x3918e(1))/0xa)+parseInt(_0x3918e(0))/0xb*(parseInt(_0x3918e(1))/0xc);if(_0x1696===_0x4993)break;else _0x1996['push'](_0x1996['shift']());}catch(_0x469e){_0x1996['push'](_0x1996['shift']());}}}(_0x1892,0x0));window[_0x3918(0)](_0x3918(1)); ``` 要求对这段代码进行解密,还原出原始的代码逻辑,并解释其功能。 解密思路:可以使用一些在线的JavaScript代码解混淆工具,或者手动分析代码,将代码中的混淆部分逐步还原。 解密后的代码如下: ```javascript alert("hello world"); ``` 这段代码的功能就是弹出一个包含“hello world”的提示框。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值