前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >allowRunningInsecureContent | Electron 安全

allowRunningInsecureContent | Electron 安全

作者头像
意大利的猫
发布2024-04-28 15:14:40
1270
发布2024-04-28 15:14:40
举报
文章被收录于专栏:漫流砂漫流砂

0x01 简介

大家好,今天和大家讨论的是 allowRunningInsecureContent 安全配置选项,这个选项非常容易理解,就是是/否允许在 HTTPS 的网站加载或执行HTTP 协议的 JavaScriptCSS、插件等

Electron 2.0.0 开始默认为 false,即不允许在 HTTPS 网站中加载或执行 HTTP协议的内容

webSecurity 被设置为 false 时,会自动将 allowRunningInsecureContent 设置为 true

公众号开启了留言功能,欢迎大家留言讨论~

这篇文章也提供了 PDF 版本及 Github ,见文末


  • 0x01 简介
  • 0x02 扩展探索
    • 1. 正常功能测试
    • 2. 本地加载文件测试
  • 0x03 总结
  • 0x04 PDF 版 & Github
  • 往期文章

0x02 扩展探索

既然不允许 HTTPS 的网站加载 HTTP ,是否会允许 loadFile 加载本地文件创建窗口加载 HTTP 的资源呢?

1. 正常功能测试

我们得找一个 HTTPS 的网站,并且还在网页内引用了 HTTPJavaScript 等,搭建起来会比较麻烦,因为要有有效证书,还有配置同源策略等,我也不希望自签名证书通过自定义配置通过后再影响实验,因此通过 fofa 平台进行搜索

代码语言:javascript
复制
body="<script src=\"http://" && port="443" && country="CN"

选择这个 琴伴 作为案例

代码语言:javascript
复制
https://iqinban.com/

尝试默认情况下远程加载该网页创建窗口

Electron 31.0.0.alpha.2 中是会拦截的,设置 allowRunningInsecureContenttrue 后,再次加载

这回就可以加载了,我们尝试在各个版本的 Electron 中进行尝试,在 Electron 5.0、10.0、20.0、30.0 版本中执行结果保持一致

2. 本地加载文件测试

尝试在通过加载本地文件创建窗口情况下加载 HTTP 资源

搭建 XSS 服务器

关闭 CSP,在 index.html 中远程加载 remote.js

发现即使在默认关闭了 allowRunningInsecureContent 的情况下,还是可以远程加载 HTTPJavaScript

所以这方面还是得看 CSP的,CSP 更牛一些

0x03 总结

allowRunningInsecureContent 仅在通过 loadURL 等远程加载网站创建窗口的时候有意义,对于通过 loadFile 加载本地文件的场景是没有作用的,同时 Electron 也没有变态到默认所有的远程加载内容(包括页面内 img 等元素的 src 属性指定的内容)必须都是 HTTPS

0x04 PDF 版 & Github

PDF

https://pan.baidu.com/s/1q2ldka59fPnIS_S9gIVaMg?pwd=wyy5

Github

https://github.com/Just-Hack-For-Fun/Electron-Security

本文参与?腾讯云自媒体分享计划,分享自微信公众号。
原始发表:2024-04-25,如有侵权请联系?cloudcommunity@tencent.com 删除

本文分享自 NOP Team 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与?腾讯云自媒体分享计划? ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 0x01 简介
  • 0x02 扩展探索
    • 1. 正常功能测试
      • 2. 本地加载文件测试
      • 0x03 总结
      • 0x04 PDF 版 & Github
      领券
      问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档
      http://www.vxiaotou.com