当前位置: 首页 > news >正文

网站开发项目的设计与实现王烨甘肃

网站开发项目的设计与实现,王烨甘肃,静态html怎么部署到服务器,苏州网站外包背景: electron大家平时为了方便使用,或是一些网上demo的引导,会让渲染进程的业务界面支持直接使用nodejs,这种开发方式有一定的安全隐患,如果业务界面因为xss之类的漏洞被注入其他代码,危害非常大&#x…

背景:

electron大家平时为了方便使用,或是一些网上demo的引导,会让渲染进程的业务界面支持直接使用nodejs,这种开发方式有一定的安全隐患,如果业务界面因为xss之类的漏洞被注入其他代码,危害非常大,属于最高等级的安全问题。那么怎样更好的避免发生这种问题呢?

一.禁止渲染进程页面直接使用nodejs,webPreferences这么配置

win = new BrowserWindow({webPreferences: {preload:"./preload.js",// Warning: Enable nodeIntegration and disable contextIsolation is not secure in production// Consider using contextBridge.exposeInMainWorld// Read more on https://www.electronjs.org/docs/latest/tutorial/context-isolationnodeIntegration: true,//webviewTag: true,contextIsolation: true,//隔离},});

二.通过preload配置,暴露允许使用调用的接口,preload配置的配置方式如上代码,内容如下例子:

import { contextBridge, ipcRenderer } from 'electron'contextBridge.exposeInMainWorld('electronAPI', {openFile: () => ipcRenderer.invoke('dialog:openFile')
})

在渲染进程界面采用window.electronAPI.openFile()方式调用,为了让渲染进程足够安全,建议设计这里的接口尽量做到仅暴露必要函数和参数,不要直接把诸如electron对象暴露给页面界面,这种事情干多了,这个安全隔离的意义就会逐渐消失。

渲染进程与preload通讯的另外一种方式,通过postmessage,举例

preload.js

window.onmessage = (ev) => {ev.data.payload === "removeLoading" && removeLoading();
};

渲染页js

postMessage({ payload: "removeLoading" }, "*");

这种方式相比第一种更加安全一点(暴露的信息更加隐蔽),但使用起来比较麻烦,可能需要进一步封装

三:其他问答:

1.preload.js在跳转到新地址后还会不会存在?

答:会,每次发生跳转preload.js都会重新加载进来,跟普通加载js一样,所以这个js的变量并非持久化的

2.preload跟主进程通讯方式

方式一:invoke和handle的组合

//preload.js
let a = ipcRenderer.invoke('xxx')//main.js
ipcMain.handle('xxx', async ()=>{
return "123"
})

方式二:on和send的组合

// 在主进程中.
const { ipcMain } = require('electron')
ipcMain.on('asynchronous-message', (event, arg) => {console.log(arg) // prints "ping"event.reply('asynchronous-reply', 'pong')
})ipcMain.on('synchronous-message', (event, arg) => {console.log(arg) // prints "ping"event.returnValue = 'pong'
})
/在渲染器进程 (网页) 中。
const { ipcRenderer } = require('electron')
console.log(ipcRenderer.sendSync('synchronous-message', 'ping')) // prints "pong"ipcRenderer.on('asynchronous-reply', (event, arg) => {console.log(arg) // prints "pong"
})
ipcRenderer.send('asynchronous-message', 'ping')

http://www.yayakq.cn/news/124287/

相关文章:

  • 区块链网站建设提供网站哪家好
  • 完成一个个人主页网站的制作seo需要会什么
  • 网站域名解析步骤如何在微信上开小程序
  • 建站平台 在线提交表格微网站如何建设方案
  • 唐山模板建站系统wordpress functions.php 路径
  • wordpress编辑网站的链接是中文推荐做幻灯片搜图网站
  • 婚庆公司网站设计专业做设计师品牌网站
  • 优化排名对网站不好红番茄 网站点评
  • 林业公司网站模版大连模板网建站
  • 售后软件网站开发自己做的网站怎么加搜索功能
  • 潍坊企业做网站网站建设的宣传词
  • 网站制作地点旅游网站建设策划书案例
  • WordPress海报搜索引擎营销简称seo
  • 扁平化色彩网站做照片的网站有哪些软件
  • 专业电商网站wordpress 文章自动标签
  • 自己怎么做网站链接郑州网络推广免费平台
  • dw网站制作模板怎样创建自己公司的网站
  • 邗江区网站建设套餐我的网站突然找不到网页了
  • wordpress酷站WordPress这新手
  • 成化区建设局网站农村自建房100张图片
  • 做销售网站要多少钱dedecms 网站地图 插件
  • 网站的建设报价如何查看wordpress版本
  • 南京哪家做网站好音乐网站答辩
  • 网站建设论文设计北京自助建站软件
  • 苏州建设公司网站免费素材免费下载
  • 阳江市网站备案幕布网站登录页一般做多大尺寸
  • 万网建站流程tk域名免费注册网站
  • 美工素材网站网站建设标准一
  • 网络公司怎么做网站无锡网络推广外包
  • 网站关键词优化怎么做正规医院看男科大概多少钱