繁体   English   中英

安全地覆盖Google Chrome扩展程序中的document.cookie

[英]Safely overriding document.cookie in Google Chrome extension

我试图在我的Chrome扩展程序中覆盖document.cookie,并且我在同时使用原始document.cookie功能时遇到了很多麻烦。 目前我有这个:

var _cookie = document.cookie; 
document.__defineSetter__("cookie", function(the_cookie) {_cookie=the_cookie;} );
document.__defineGetter__("cookie", function() {return _cookie;} );

我正在使用此处的技术从内容脚本中注入JS。

我看到的行为是我的重新定义的setter和getter被调用,但原始函数不再有效。 例如,我可以使用开发人员工具检查_cookie和document.cookie,看看它们是否具有相同的预期值,但Chrome的cookie商店中没有任何Cookie。

任何人都可以告诉我我是如何打破原始document.cookie功能的? document.cookie是一个属性的问题,所以我实际上并没有获得指向原始setter的指针?

var _cookie = document.cookie; 没有保存cookie的原始getter和setter,它只是调用getter并保存结果。

这个页面原始链接 ,现在已经破了)有一个如何保存cookie setter和getter的例子:

var cookie_setter = document.__lookupSetter__ ('cookie');
var cookie_getter = document.__lookupGetter__ ('cookie');

您已经重新定义了orignal cookie getter和setter函数,并且您可能有可能忘记了新函数中原始函数的重要部分或实现

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM