Electron 预加载脚本(10)

我谈了很多关于Electron安全的问题。但是,前端完全访问你的系统并不是一个好主意。Electron推荐如何处理?

当前的解决方案--是预加载脚本。

我们仍然有前端和后端代码,但我们还有第三种代码------预加载脚本。它在将控制权交给常规代码之前,初始化并执行任何高级权限的操作。

启用预加载脚本

让我们从我们在上一篇文章开始。我们需要去掉nodeIntegration:true和contextIsolation:false。

出于某种原因,Electron真的希望预加载路径是绝对路径,而不是相对路径:

js 复制代码
let { app, BrowserWindow } = require("electron")

function createWindow() {
  let win = new BrowserWindow({
    webPreferences: {
      preload: `${__dirname}/preload.js`,
    },
  })
  win.maximize()
  win.loadFile("index.html")
}

app.on("ready", createWindow)

app.on("window-all-closed", () => {
  app.quit()
})

预加载脚本

让我们将runCommand移动到preload.js,并使用contextBridge公开它:

js 复制代码
let child_process = require("child_process")
let { contextBridge } = require("electron")

let runCommand = (command) => {
  return child_process.execSync(command).toString().trim()
}

contextBridge.exposeInMainWorld(
  "api", { runCommand }
)

contextBridge.exposeInMainWorld 定义了我们在前端暴露的内容。在本例中,将runCommand 挂载到 window.api。

使用预加载脚本

在前端脚本中,我们只需要更改两行-删除require。因为,它不再起作用,并调用我们公开的方法window.API.runCommand而不是child_process.execSync

js 复制代码
form.addEventListener("submit", (e) => {
  e.preventDefault()
  let command = input.value
  let output = window.api.runCommand(command)
  createTerminalHistoryEntry(command, output)
  input.value = ""
  input.scrollIntoView()
})

代码

app.js

js 复制代码
let form = document.querySelector("form")
let input = document.querySelector("input")
let terminalHistory = document.querySelector("#history")

function createInputLine(command) {
  let inputLine = document.createElement("div")
  inputLine.className = "input-line"

  let promptSpan = document.createElement("span")
  promptSpan.className = "prompt"
  promptSpan.append("$")
  let inputSpan = document.createElement("span")
  inputSpan.className = "input"
  inputSpan.append(command)

  inputLine.append(promptSpan)
  inputLine.append(inputSpan)

  return inputLine
}

function createTerminalHistoryEntry(command, commandOutput) {
  let inputLine = createInputLine(command)
  let output = document.createElement("div")
  output.className = "output"
  output.append(commandOutput)
  terminalHistory.append(inputLine)
  terminalHistory.append(output)
}

form.addEventListener("submit", (e) => {
  e.preventDefault()
  let command = input.value
  let output = window.api.runCommand(command)
  createTerminalHistoryEntry(command, output)
  input.value = ""
  input.scrollIntoView()
})

原文:dev.to/taw/electro...

相关推荐
升鲜宝供应链及收银系统源代码服务2 小时前
《IntelliJ + Claude Code + Gemini + ChatGPT 实战配置手册升鲜宝》
java·前端·数据库·chatgpt·供应链系统·生鲜配送
i建模2 小时前
将Edge浏览器的标签页从顶部水平排列**移至左侧垂直侧边栏
前端·edge
跟着珅聪学java2 小时前
js编写中文转unicode 教程
前端·javascript·数据库
英俊潇洒美少年3 小时前
Vue3 深入响应式系统
前端·javascript·vue.js
英俊潇洒美少年4 小时前
React 最核心 3 大底层原理:Fiber + Diff + 事件系统
前端·react.js·前端框架
我命由我123454 小时前
React Router 6 - 概述、基础路由、重定向、NavLink、路由表
前端·javascript·react.js·前端框架·ecmascript·html5·js
LJianK14 小时前
java封装
java·前端·数据库
yaaakaaang4 小时前
(四)前端,如此简单!---Promise
前端·javascript
GISer_Jing5 小时前
ReAct规划原理实战指南
前端·react.js·ai·aigc
SoaringHeart5 小时前
Flutter组件封装:翻转组件 NFlipCard
前端·flutter