- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我是greasemonkey 的新手,并试图了解greasemonkey 与嵌入式Web 控制台有何不同。一个在 Web 控制台上完美运行的简单脚本在 Greasemonkey 上不起作用,我不知道为什么。
Arch Linux 上的 Firefox 74.0
油猴4.9
这是我使用的测试脚本:
(function() {
"use strict";
const w = window.open('https://www.google.com/', 'w');
console.log("Hello");
w.onload = () => {
console.log("World");
};
})();
当我访问https://www.google.com/webhp?gl=us&hl=en&gws_rd=cr&pws=0时(Google US首页),将脚本复制并粘贴到Web控制台中,然后执行它,
一个新窗口w
正在加载https://www.google.com/已打开。
打印字符串 Hello
。
打印字符串 World
。
一切都如预期。
在greasemonkey上,我使用下面的脚本。 header 部分是唯一的区别。
// ==UserScript==
// @name test
// @namespace n
// @match https://www.google.com/webhp?gl=us&hl=en&gws_rd=cr&pws=0
// ==/UserScript==
(function() {
"use strict";
const w = window.open('https://www.google.com/', 'w');
console.log("Hello");
w.onload = () => {
console.log("World");
};
})();
当我访问https://www.google.com/webhp?gl=us&hl=en&gws_rd=cr&pws=0时(Google 美国首页),
一个新窗口w
正在加载https://www.google.com/已打开。
打印字符串 Hello
。
SecurityError
抛出说
Script error in [Greasemonkey script n/test]:
SecurityError: Permission denied to access property "onload" on cross-origin object test:42:19
user-script:n/test:42
当我使用 unsafeWindow
而不是 window
时,
一个新窗口w
正在加载https://www.google.com/已打开。
打印字符串 Hello
。
没有其他事情发生。 (没有错误,没有世界
)
我应该如何修改脚本以便可以在greasemonkey上执行?
<小时/>更新
根据this comment ,该脚本适用于 Chrome 下的 Tampermonkey 或 Violentmonkey。
我尚未确认这一点,但已确认该脚本可以在 Firefox 下的 Tampermonkey 4.10.6105
或 Violentmonkey 2.12.7
上运行。
最佳答案
Web 控制台是浏览器范围的一部分,而 GreaseMonkey 脚本被注入(inject)到页面内容中,其范围仅限于该页面。
您可以使用 GM 从页面内容打开一个新选项卡/窗口,但该窗口/选项卡将具有其自己的页面内容范围,该范围与第一个页面内容范围分开。因此,您无法从不同选项卡的页面内容访问属于另一个选项卡/窗口的属性。
这种分离适用于所有内容脚本,而不仅仅是 GM。否则,如果一个选项卡/页面中的 JS 可以访问其他选项卡上的数据,就会产生很大的安全风险。
更新:
正如 wOxxOm 所指出的,CSP 和跨源策略阻止 Cross-Origin Resource Sharing (CORS) .
在您的示例中,在 Firefox 中,第一个问题是 Firefox 将从内容脚本中“阻止弹出窗口”。
测试 Firefox 专用 userScripts API FireMonkey ,允许弹出后,仍然报错:
SecurityError: Permission denied to access property "onload" on cross-origin object
在这种情况下,我认为这是由于出于安全考虑而对 userScripts 进行了沙箱处理。
GM/TM/VM 不使用 userScripts API 并使用其他方式注入(inject) userSripts,这会导致不同的结果。
关于javascript - Greasemonkey 为一个简单的脚本抛出 SecurityError,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/60903868/
这个问题在这里已经有了答案: How to call Greasemonkey's GM_ functions from code that must run in the target page s
是否可以使用 Greasemonkey 脚本跨域存储数据?我想允许从使用相同 Greasemonkey 脚本的多个网站访问 Javascript 对象。 最佳答案 是的,这就是 GM_setvalue
我有一个简单的 Greasemonkey 脚本: // ==UserScript== // @name hello // @namespace http://www.webmonkey.com //
我想写一个非常简单的 greasemonkey 脚本,因为我讨厌“你确定吗?”我经常使用的网站上的 javascript 确认。我只是将它用于个人用途,不会发布它或任何东西。经过一番谷歌搜索后,我找到
这是一个有点奇怪的具体问题。 我正在编写一个可以跨十个域运行的 Greasemonkey 脚本。这些网站都具有相同的结构,但每个网站的域名不同。例如,脚本将运行: http://first-domai
我为一个域制作了一个greasemonkey脚本,现在如何让它只运行一次?就像每次访问域时它都会启动一样,我不希望这样。如何使其仅运行一次,然后删除自身或使其处于非事件状态? 谢谢。 最佳答案 如果您
我发现了很多类似的问题,但没有一个是平等的,也没有正确的解决方案。这是一个非常奇怪的问题。 我有一个简单的 Greasemonkey 脚本来测试这个问题: // ==UserScript== // @
我正在写一个 Greasemonkey 脚本,如何实现自动更新? 可以将脚本放入 GitHub 存储库并设置 @version数字? 然后......是一些自动的方式如何做到这一点?或者我必须手动检查
我现在正在研究用户脚本。我知道 Opera 与 Greasemonkey 脚本的许多方面兼容,但与其他方面不兼容。 GM functions emulation script在 Opera 上将需要,
最近在写一个用户脚本时,我发现页面上下文中的变量是可用的。 console.log(window) 在 Tampermonkey 和 Greasemonkey 中都没有导致错误。 我很困惑。全局变量不
看完后Greasemonkey recommends users to install Tampermonkey or Violentmonkey . 我已经安装了 Tampermonkey,现在我正
我在一堆 div 和一个表单中包含了一些输入值。我对 js 的了解有限,想在页面加载时使用油脂猴来设置值。 下面显示了获取值的 div 和表单的顺序。
有没有办法使用用户脚本将一些设置保存到不是 cookie 的本地计算机? 如果设置不是全局的,则很难制作用于多个域的用户脚本。 来自评论: "I am using scriptish " 。 最佳答案
我有一个带有以下元块的油脂猴脚本- // ==UserScript== // @name TDF Improved Dark Skin // @namespace TDF // @incl
我有用于Firefox的Greasemonkey脚本。该脚本包括此元块和一些代码行。 我想在服务器上更新脚本,然后自动更新浏览器的脚本。 requireSecureUpdates选项已关闭。 我究竟做
我正在按照说明将 Greasemonkey 脚本传输到 Tampermonkey:How to Transfer All Greasemonkey userscripts to Tampermonke
This question already has an answer here: My very simple Greasemonkey script is not running? (1个答案)
我需要在公司内部网站上托管用户脚本。我如何构建 href这样 Greasemonkey 会在点击链接时安装用户脚本吗? 我尝试了一个简单的 Install Userscript但是 Chrome 和
例如,在远程网页中,有如下代码片段: function foo(){ this.bar = 0; } 在我的油脂猴子脚本中,我想创建此类的对象: var _foo= unsafeWindow['fo
我想在文档中选择文本后调用函数。以下代码无效 var showSelWin = document.getElementById('innerwindow'); var txt = ' '; if (d
我是一名优秀的程序员,十分优秀!