首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >SonarJs仍然显示关于postMessage跨域问题的警告。

SonarJs仍然显示关于postMessage跨域问题的警告。
EN

Stack Overflow用户
提问于 2019-01-11 01:44:18
回答 2查看 3.7K关注 0票数 2

错误消息是"make sure this cross-domain message is being sent to the intended domain"

此检查规则来自RSPEC-2819

作者不应在包含任何机密信息的邮件中使用targetOrigin参数中的通配符关键字( *),因为否则无法保证消息只传递给收件人。

我假设它要求*不能用作targetOrigin,但当我将预期域作为targetOrigin使用时,它仍然显示警告,如下所示:

有人能告诉我怎么通过这张支票吗?

如能提供任何帮助,将不胜感激。

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2019-01-22 07:53:17

此规则仅检测是否在具有包含postMessage的名称的对象上调用方法window。源代码:PostMessageCheck.java。要绕过它,只需将contentWindow对象分配到不同的对象,如下所示:

代码语言:javascript
复制
var content = this.elem.contentWindow;

content.postMessage('your message', window.location.origin);
票数 5
EN

Stack Overflow用户

发布于 2021-06-24 16:28:42

在sonarQube中也遇到了类似的问题。下面的fix成功了。只需摆脱直接使用窗口对象。

实际代码:

代码语言:javascript
复制
window.parent.postMessage("data", parenturl);

修正:

代码语言:javascript
复制
var content=window;
content.parent.postMessage("data",parenturl);
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/54139298

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档