js 恢复劫持的变量

劫持了alert

window.alert = 'a'

如何继续在当前页alert呢?(iframe之类的 除外,在当前域下)

以前有人解答过两种方法——
第一种 delete alert就好了。。现在不行了。什么原因啊。。浏览器新特性?
第二种 用函数原型但是我给忘了、。。。

阅读 3.8k
3 个回答

alertwindowconfigurable属性,删除了就是删除了,怎么会自己变成原来的alert函数呢?你说的原型的方式,倒是有一种可能,比如:

function Person(){}
Person.prototype.say = function(){console.log('from person')}
var p = new Person();
p.say()// from person
p.say = function(){console.log('from instance')}
p.say()// from instance
delete p.say
p.say()// from person

我想了一种方法

function fix() {
  var iframe = document.createElement('iframe')
  iframe.src = 'about:blank'
  document.body.appendChild(iframe)
  window.alert = iframe.contentWindow.alert
}

window.alert = ''
alert() // error
fix()
alert() // succ

用一个变量保存起来
_alert=alert

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题
宣传栏