使用 Docker 搭建,浏览器访问出现:fetch post error ReferenceError: ipcRenderer is not defined

本贴最后更新于 394 天前,其中的信息可能已经时移世易

使用 Docker 搭建,浏览器访问出现:fetch post error ReferenceError: ipcRenderer is not defined

错误截图:

QQ 截图 20240501233221.png


错误代码如下:

main.88649b38368b4e2ea292.js:3314 fetch post error ReferenceError: ipcRenderer is not defined at Rs (main.88649b38368b4e2ea292.js:6068:22165) at oL (main.88649b38368b4e2ea292.js:6068:24088) at main.88649b38368b4e2ea292.js:6068:28842 at main.88649b38368b4e2ea292.js:3314:3432 (匿名) @ main.88649b38368b4e2ea292.js:3314 Promise.catch(异步) L @ main.88649b38368b4e2ea292.js:3314 (匿名) @ main.88649b38368b4e2ea292.js:6068 (匿名) @ main.88649b38368b4e2ea292.js:3314 Promise.then(异步) lf @ main.88649b38368b4e2ea292.js:3314 (匿名) @ main.88649b38368b4e2ea292.js:6068 (匿名) @ main.88649b38368b4e2ea292.js:9 (匿名) @ main.88649b38368b4e2ea292.js:3314 Promise.then(异步) L @ main.88649b38368b4e2ea292.js:3314 ki @ main.88649b38368b4e2ea292.js:9 (匿名) @ main.88649b38368b4e2ea292.js:6068 s @ main.88649b38368b4e2ea292.js:6068 Promise.then(异步) l @ main.88649b38368b4e2ea292.js:6068 (匿名) @ main.88649b38368b4e2ea292.js:6068 cL @ main.88649b38368b4e2ea292.js:6068 (匿名) @ main.88649b38368b4e2ea292.js:6068 (匿名) @ main.88649b38368b4e2ea292.js:3314 Promise.then(异步) L @ main.88649b38368b4e2ea292.js:3314 dL @ main.88649b38368b4e2ea292.js:6068 (匿名) @ main.88649b38368b4e2ea292.js:6068 (匿名) @ main.88649b38368b4e2ea292.js:6068 (匿名) @ main.88649b38368b4e2ea292.js:6068 (匿名) @ main.88649b38368b4e2ea292.js:6068

郁闷了,一直以为是 Docker 搭建有问题,结果手机打开测试一下,发现是浏览器问题,ChatGPT 回答如下:

在浏览器中无法直接开启支持 Electron 的 IPC(进程间通信)模块,因为浏览器和 Electron 是两种不同的环境,浏览器不具备 Electron 的这些特定功能。Electron 是一个基于 Chromium 和 Node.js 的框架,它允许您使用 Node.js 模块和 Electron API 来构建桌面应用程序。

如果您的代码需要在浏览器和 Electron 环境下都能正常运行,通常需要进行一些条件判断和代码调整,以便在不同环境下使用不同的功能或模块。

下面是一种常见的做法,可以帮助您在浏览器环境下模拟简单的 IPC 通信:

  1. 使用 Web APIs: 在浏览器环境下,您可以使用 Web APIs 来进行类似于 IPC 的通信,比如使用 window.postMessage() 方法进行跨窗口通信。
  2. 模拟 IPC: 您可以编写自定义的通信层,模拟 Electron 中的 IPC 功能。例如,可以通过 WebSocket 或者基于服务器的消息传递来实现进程间通信。
  3. 条件判断: 在代码中进行环境检测,根据当前环境选择是否使用特定的模块或功能,如前面提到的示例代码片段。

总的来说,要在浏览器中模拟 Electron 的 IPC 功能,您需要重新设计您的代码逻辑,使用浏览器环境下可用的替代方案来实现您的需求。如果您有特定的需求或代码示例,欢迎分享,我将尽力提供更具体的帮助和建议。

  • 思源笔记

    思源笔记是一款隐私优先的个人知识管理系统,支持完全离线使用,同时也支持端到端加密同步。

    融合块、大纲和双向链接,重构你的思维。

    25739 引用 • 106524 回帖
  • Q&A

    提问之前请先看《提问的智慧》,好的问题比好的答案更有价值。

    9864 引用 • 44837 回帖 • 77 关注

相关帖子

欢迎来到这里!

我们正在构建一个小众社区,大家在这里相互信任,以平等 • 自由 • 奔放的价值观进行分享交流。最终,希望大家能够找到与自己志同道合的伙伴,共同成长。

注册 关于
请输入回帖内容 ...
  • virtualfox

    今天刚装不行,还有这个问题,

    1 回复
  • 其他回帖
  • live2

    OK,拉取旧版本已解决

    docker run -d \ --name siyuan \ --user root:root \ -v /volume1/docker/siyuan/workspace:/siyuan/workspace \ -p 6888:6806 \ --restart always \ b3log/siyuan:v3.0.11 \ --workspace=/siyuan/workspace --lang=zh_CN --accessAuthCode=admin --ssl="false"
  • 3.0.13 还没发布,可以先用 3.0.11

  • twilight1015 via macOS

    从 docker 上拉 latest 的版本好像还是 2 天前的版本

  • 查看全部回帖

推荐标签 标签

  • Gitea

    Gitea 是一个开源社区驱动的轻量级代码托管解决方案,后端采用 Go 编写,采用 MIT 许可证。

    5 引用 • 16 回帖 • 2 关注
  • 宕机

    宕机,多指一些网站、游戏、网络应用等服务器一种区别于正常运行的状态,也叫“Down 机”、“当机”或“死机”。宕机状态不仅仅是指服务器“挂掉了”、“死机了”状态,也包括服务器假死、停用、关闭等一些原因而导致出现的不能够正常运行的状态。

    13 引用 • 82 回帖 • 77 关注
  • 资讯

    资讯是用户因为及时地获得它并利用它而能够在相对短的时间内给自己带来价值的信息,资讯有时效性和地域性。

    56 引用 • 85 回帖
  • 印象笔记
    3 引用 • 16 回帖 • 2 关注
  • 创造

    你创造的作品可能会帮助到很多人,如果是开源项目的话就更赞了!

    186 引用 • 1020 回帖
  • 支付宝

    支付宝是全球领先的独立第三方支付平台,致力于为广大用户提供安全快速的电子支付/网上支付/安全支付/手机支付体验,及转账收款/水电煤缴费/信用卡还款/AA 收款等生活服务应用。

    29 引用 • 347 回帖
  • LaTeX

    LaTeX(音译“拉泰赫”)是一种基于 ΤΕΧ 的排版系统,由美国计算机学家莱斯利·兰伯特(Leslie Lamport)在 20 世纪 80 年代初期开发,利用这种格式,即使使用者没有排版和程序设计的知识也可以充分发挥由 TeX 所提供的强大功能,能在几天,甚至几小时内生成很多具有书籍质量的印刷品。对于生成复杂表格和数学公式,这一点表现得尤为突出。因此它非常适用于生成高印刷质量的科技和数学类文档。

    12 引用 • 59 回帖 • 5 关注
  • 小说

    小说是以刻画人物形象为中心,通过完整的故事情节和环境描写来反映社会生活的文学体裁。

    32 引用 • 108 回帖
  • 大疆创新

    深圳市大疆创新科技有限公司(DJI-Innovations,简称 DJI),成立于 2006 年,是全球领先的无人飞行器控制系统及无人机解决方案的研发和生产商,客户遍布全球 100 多个国家。通过持续的创新,大疆致力于为无人机工业、行业用户以及专业航拍应用提供性能最强、体验最佳的革命性智能飞控产品和解决方案。

    2 引用 • 14 回帖 • 1 关注
  • Kafka

    Kafka 是一种高吞吐量的分布式发布订阅消息系统,它可以处理消费者规模的网站中的所有动作流数据。 这种动作(网页浏览,搜索和其他用户的行动)是现代系统中许多功能的基础。 这些数据通常是由于吞吐量的要求而通过处理日志和日志聚合来解决。

    36 引用 • 35 回帖 • 7 关注
  • 星云链

    星云链是一个开源公链,业内简单的将其称为区块链上的谷歌。其实它不仅仅是区块链搜索引擎,一个公链的所有功能,它基本都有,比如你可以用它来开发部署你的去中心化的 APP,你可以在上面编写智能合约,发送交易等等。3 分钟快速接入星云链 (NAS) 测试网

    3 引用 • 16 回帖 • 2 关注
  • RemNote
    2 引用 • 16 回帖 • 14 关注
  • Vditor

    Vditor 是一款浏览器端的 Markdown 编辑器,支持所见即所得、即时渲染(类似 Typora)和分屏预览模式。它使用 TypeScript 实现,支持原生 JavaScript、Vue、React 和 Angular。

    371 引用 • 1854 回帖 • 2 关注
  • MySQL

    MySQL 是一个关系型数据库管理系统,由瑞典 MySQL AB 公司开发,目前属于 Oracle 公司。MySQL 是最流行的关系型数据库管理系统之一。

    693 引用 • 537 回帖
  • Caddy

    Caddy 是一款默认自动启用 HTTPS 的 HTTP/2 Web 服务器。

    10 引用 • 54 回帖 • 176 关注
  • 职场

    找到自己的位置,萌新烦恼少。

    127 引用 • 1708 回帖 • 1 关注
  • V2EX

    V2EX 是创意工作者们的社区。这里目前汇聚了超过 400,000 名主要来自互联网行业、游戏行业和媒体行业的创意工作者。V2EX 希望能够成为创意工作者们的生活和事业的一部分。

    16 引用 • 236 回帖 • 253 关注
  • 服务

    提供一个服务绝不仅仅是简单的把硬件和软件累加在一起,它包括了服务的可靠性、服务的标准化、以及对服务的监控、维护、技术支持等。

    41 引用 • 24 回帖
  • AWS
    11 引用 • 28 回帖 • 2 关注
  • Flutter

    Flutter 是谷歌的移动 UI 框架,可以快速在 iOS 和 Android 上构建高质量的原生用户界面。 Flutter 可以与现有的代码一起工作,它正在被越来越多的开发者和组织使用,并且 Flutter 是完全免费、开源的。

    39 引用 • 92 回帖 • 4 关注
  • 深度学习

    深度学习(Deep Learning)是机器学习的分支,是一种试图使用包含复杂结构或由多重非线性变换构成的多个处理层对数据进行高层抽象的算法。

    43 引用 • 44 回帖
  • SEO

    发布对别人有帮助的原创内容是最好的 SEO 方式。

    35 引用 • 200 回帖 • 31 关注
  • 链滴

    链滴是一个记录生活的地方。

    记录生活,连接点滴

    178 引用 • 3866 回帖 • 1 关注
  • 学习

    “梦想从学习开始,事业从实践起步” —— 习近平

    172 引用 • 534 回帖
  • 微软

    微软是一家美国跨国科技公司,也是世界 PC 软件开发的先导,由比尔·盖茨与保罗·艾伦创办于 1975 年,公司总部设立在华盛顿州的雷德蒙德(Redmond,邻近西雅图)。以研发、制造、授权和提供广泛的电脑软件服务业务为主。

    8 引用 • 44 回帖
  • Kotlin

    Kotlin 是一种在 Java 虚拟机上运行的静态类型编程语言,由 JetBrains 设计开发并开源。Kotlin 可以编译成 Java 字节码,也可以编译成 JavaScript,方便在没有 JVM 的设备上运行。在 Google I/O 2017 中,Google 宣布 Kotlin 成为 Android 官方开发语言。

    19 引用 • 33 回帖 • 78 关注
  • 电影

    这是一个不能说的秘密。

    122 引用 • 608 回帖