js 恢复劫持的变量

膜拜tomato
  • 102

劫持了alert

window.alert = 'a'

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

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

评论
阅读 1.9k
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

撰写回答

登录后参与交流、获取后续更新提醒

宣传栏