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

福建省住房城乡建设厅网站网站定制那个好

福建省住房城乡建设厅网站,网站定制那个好,免费发布软文广告推广平台,萝岗定制型网站建设前言 window环境。 electron28.0.0 sqlite35.1.6 使用 electron-builder 打包。 本文旨在解决打包后无法写入数据库的问题。 但如果你是打包后无法访问sqlite,且有报错弹窗,不妨也看看本文。 也许是同一种原因。 错误原因分析 打包后无法创建db文件&…

前言

window环境。

electron@28.0.0
sqlite3@5.1.6
使用 electron-builder 打包。

本文旨在解决打包后无法写入数据库的问题。

但如果你是打包后无法访问sqlite,且有报错弹窗,不妨也看看本文。
也许是同一种原因。

错误原因分析

打包后无法创建db文件,是因为大部分人连接db,
都是用path模块,采用
path.join(__dirname, 'data.db') 类似这样的写法。

因为网上的垃圾教程都是这么教的,笔者也深受其害。

默认情况下,打包后获得的目录格式为(假设你的输出目录是dist/

/dist/xxx.exe
/dist/resources/app.asar

xxx.exe是你的主程序。

electron打包后的项目根目录,指向app.asar 文件。

所以如果你在node里写的源代码是

const filePath = path.resolve(app.getAppPath(), 'storage', 'data.db')
const db = new sqlite3.Database(filePath)

在打包后,程序执行到这里,会去请求/dist/resources/app.asar/storage/data.sb文件。

再举一个例子,
假如你的项目目录是

myproject/package.json
myproject/main.js
myproject/src/dbserver/mydb.js
myproject/src/storage/data.db

然后在你mydb.js中这样写

const filePath = path.resolve(__dirname, '../storage/data.db')
const db = new sqlite3.Database(filePath)

在调试时候肯定是没问题的。

但是打包后,所有资源默认都被打包进app.asar,且根目录符号链接到app.asar
程序执行到这里就会请求/resources/app.asar/src/storage/data.db这个地址。

如果你的打包设置是正确的,这一步并不会报错,因为data.db的的确确被打包进了这个路径。
你可以正确读取。

但是 app.asar是一个只可读不可写的文件。
当你要写入数据库的时候,就会发现怎么都无法写,甚至程序不报错。
因为用promise封装的db写入请求,只会一直pending,而不会reject。

为什么 app.asar只可读不可写?
某种意义上你可以把它看成程序的一部分。
如果app.asar被改写了,你可以认为你的程序遭到了入侵。
一般而言electron甚至鼓励你去校验app.asar的完整性,来确保自己的分发版本是正确的。

看起来这是一个合理的设计。

所以我们要做的应该是,让我们的db请求路径,不要指向app.asar

正确解法

不要使用node提供的相对路径功能。
不要使用__dirname 变量。
不要使用electron.app.getAppPath()
这些东西最后都会指向app.asar

在生产环境就写一个相对路径字符串。

const isPackaged = app.isPackaged;
let filePath;
if(isPackaged){filePath = path.resolve('./resources/storage/data.db')
}
else{filePath = path.resolve(__dirname, '../storage/data.db')
}
const db = new sqlite3.Database(filePath)

同时在pakcge.json中配置extraResources字段。

"build":{"extraResources":  {"from": "./src/storage/","to": "storage"},
}

这样整个/myproject/src/storage 目录都会被复制到/dist/resources/storage/位置。

这样最后程序执行db时,会指向/dist/resources/storage/data.db位置。
因为在path.resolve('./resources/storage/data.db') 这条命令中的,. 指向当前xxx.exe的运行位置。

这同样暗示我们,data.db应该作为一个外部文件管理,不应该放在src里。
src应该视为程序本体,在打包后,运行时,永远不变。
data.db这种属于外部资源,打包后运行时会动态改变。
外部资源不应该在src里。
我上面举例的这种项目结构是不合理的。


文章转载自:

http://xxl4dsg8.sskns.cn
http://mbeZT1JG.sskns.cn
http://tioSJmtp.sskns.cn
http://dD6iutK6.sskns.cn
http://Cz5kwi6A.sskns.cn
http://7LCXzv19.sskns.cn
http://XZGgm0s4.sskns.cn
http://twFz6JVR.sskns.cn
http://LPBz5OpG.sskns.cn
http://AB4ujxIO.sskns.cn
http://cxtJt1rf.sskns.cn
http://ViD3XsdX.sskns.cn
http://HccHNa3J.sskns.cn
http://chVFkHbt.sskns.cn
http://giqZ9Ox4.sskns.cn
http://bInInWPA.sskns.cn
http://kgE2m6oO.sskns.cn
http://YOe88qeJ.sskns.cn
http://11XiyEKf.sskns.cn
http://DVcJdFt3.sskns.cn
http://4typGGnU.sskns.cn
http://M0NFdXNv.sskns.cn
http://mlSNuxb6.sskns.cn
http://r0trJrTg.sskns.cn
http://CX7p7A8Z.sskns.cn
http://3vNoeP64.sskns.cn
http://RPbNM5xq.sskns.cn
http://2isygMVx.sskns.cn
http://4ZECS6w7.sskns.cn
http://h6zqHicE.sskns.cn
http://www.dtcms.com/wzjs/659728.html

相关文章:

  • oppo手机应用商店使用最佳搜索引擎优化工具
  • 做网站需要哪些东西做编程网站有哪些
  • 榆次做企业网站怎么做最简单的网站
  • 网站建设在国外同城app开发价目表
  • 外链建设都需要带网站网址怎么注册网络科技公司
  • 做网站至少多少钱做网站做什么赚钱
  • 会计网站模板电商运营团队结构图
  • 佛山营销型网站建设如何做推广呢
  • 长沙市做网站的建设网站公司兴田德润
  • 做门户网站用什么软件wordpress伪静态iis6
  • 网站建设第一品牌 网站设计西安微信网站开发
  • 微网站建设及微信推广方案wordpress评论回复邮箱
  • wordpress建多个网站漳州手机网站建设公司哪家好
  • 哪里有做网站服务商php5mysql网站开发实例精讲
  • 福永镇网站建设一家装修的网站怎么做的
  • 泉州网站建设工作室域名交易asp.net 网站
  • 长春市建设局网站博海博海网站建设
  • 淘宝客绑定网站备案号seo是什么的缩写
  • 电商网站里的图片wordpress+伪静态+403
  • 画出网站开发项目流程图成都 网站建设 公司哪家好
  • 电商网站开发fd互联网app开发
  • 建站网站苏州自媒体写作平台
  • 做了个网站 怎么做seo长沙铭万做网站
  • 购物网站开发百度一下 官方网
  • 餐饮类网站设计较好的网站模板
  • 怎么查询建设通网站企业网站seo优化交流
  • 手机网站怎么开发编程培训机构哪里好
  • 自己怎么开网站备案中国建设招标网住建部网站
  • 网站优化时间建e网室内设计效果图餐厅
  • 网站模板建设二级目录中文网站欣赏