当前位置:首页 > 文章列表 > Golang > Go问答 > 将预编译的二进制文件捆绑到电子应用程序中

将预编译的二进制文件捆绑到电子应用程序中

来源:stackoverflow 2024-03-29 23:42:36 0浏览 收藏

本篇文章主要是结合我之前面试的各种经历和实战开发中遇到的问题解决经验整理的,希望这篇《将预编译的二进制文件捆绑到电子应用程序中》对你有很大帮助!欢迎收藏,分享给更多的需要的朋友学习~

问题内容

关于如何将第三方预编译的二进制文件(例如 imagemagick)包含到电子应用程序中,是否有一个好的解决方案?有 Node.js 模块,但它们都是包装器或本机绑定到系统范围内安装的库。我想知道是否可以在发行版中捆绑预编译的二进制文件。


正确答案


请参阅下面的更新(此方法目前并不理想)。

我确实找到了解决方案,但我不知道这是否被认为是最佳实践。我找不到任何好的文档来包含第三方预编译的二进制文件,所以我只是摆弄它,直到它最终与我的 ffmpeg 二进制文件一起工作。这是我所做的(从电子快速入门,node.js v6 开始):

mac os x 方法

从应用程序目录中,我在终端中运行以下命令,将 ffmpeg 二进制文件包含为模块:

mkdir node_modules/ffmpeg
cp /usr/local/bin/ffmpeg node_modules/ffmpeg/
cd node_modules/.bin
ln -s ../ffmpeg/ffmpeg ffmpeg

(将 /usr/local/bin/ffmpeg 替换为您当前的二进制路径,从此处下载)放置链接允许 electro-packager 包含我保存到 node_modules/ffmpeg/ 的二进制文件。

然后为了获取捆绑的应用程序路径(以便我可以为我的二进制文件使用绝对路径...无论我做什么,相对路径似乎都不起作用)我安装了 npm 包 app-root-dir运行以下命令:

npm i -s app-root-dir

现在我有了根应用程序目录,我只需为我的二进制文件附加子文件夹并从那里生成。这是我放置在 renderer.js 中的代码:。

var approotdir = require('app-root-dir').get();
var ffmpegpath=approotdir+'/node_modules/ffmpeg/ffmpeg';
console.log(ffmpegpath);

const
    spawn = require( 'child_process' ).spawn,
    ffmpeg = spawn( ffmpegpath, ['-i',clips_input[0]]);  //add whatever switches you need here

ffmpeg.stdout.on( 'data', data => {
     console.log( `stdout: ${data}` );
    });
   ffmpeg.stderr.on( 'data', data => {
console.log( `stderr: ${data}` );
    });

windows方法

  1. 打开您的电子基础文件夹(电子快速启动是默认名称),然后进入node_modules文件夹。在那里创建一个名为 ffmpeg 的文件夹,并将静态二进制文件复制到该目录中。注意:它必须是二进制文件的静态版本,对于 ffmpeg,我获取了最新的 windows 版本 here

  2. 为了获取捆绑的应用程序路径(以便我可以为我的二进制文件使用绝对路径...无论我做什么,相对路径似乎都不起作用)我安装了 npm 包 app-root- dir 通过在我的应用程序目录中的命令提示符下运行以下命令:

    npm i -s app-root-dir
  3. 在 node_modules 文件夹中,导航到 .bin 子文件夹。您需要在此处创建几个文本文件,以告诉节点包含您刚刚复制的二进制 exe 文件。使用您最喜欢的文本编辑器创建两个文件,其中一个名为 ffmpeg,其中包含以下内容:

    #!/bin/sh
    basedir=$(dirname "$(echo "$0" | sed -e 's,\\,/,g')")
    
    case `uname` in
        *cygwin*) basedir=`cygpath -w "$basedir"`;;
    esac
    
    if [ -x "$basedir/node" ]; then
      "$basedir/node"  "$basedir/../ffmpeg/ffmpeg" "$@"
      ret=$?
    else
      node  "$basedir/../ffmpeg/ffmpeg" "$@"
      ret=$?
    fi
    exit $ret

第二个文本文件,名为 ffmpeg.cmd

@if exist "%~dp0\node.exe" (
     "%~dp0\node.exe"  "%~dp0\..\ffmpeg\ffmpeg" %*
    ) else (
       @setlocal
     @set pathext=%pathext:;.js;=;%
     node  "%~dp0\..\ffmpeg\ffmpeg" %*
    )

接下来,您可以在 windows 电子发行版(在 renderer.js 中)中运行 ffmpeg,如下所示(我也使用 app-root-dir 节点模块)。请注意添加到二进制路径的引号,如果您的应用程序安装到带有空格的目录(例如 c:\program files\yourapp),没有这些引号它将无法工作。

var approotdir = require('app-root-dir').get();
var ffmpegpath = approotdir + '\\node_modules\\ffmpeg\\ffmpeg';

const
    spawn = require( 'child_process' ).spawn;
    var ffmpeg = spawn( 'cmd.exe', ['/c',  '"'+ffmpegpath+ '"', '-i', clips_input[0]]);  //add whatever switches you need here, test on command line first
ffmpeg.stdout.on( 'data', data => {
     console.log( `stdout: ${data}` );
 });
ffmpeg.stderr.on( 'data', data => {
     console.log( `stderr: ${data}` );
 });

更新:统一简单方法

随着时间的推移和 node 的更新,这种方法不再是包含预编译二进制文件的最简单方法。它仍然有效,但是当运行 npm install 时,node_modules 下的二进制文件夹将被删除,并且必须再次替换。以下方法适用于 node v12。

这种新方法消除了符号链接的需要,并且在 mac 和 windows 上的工作方式类似。相对路径现在似乎可以工作。

  1. 您仍然需要 approotdir:npm i -s app-root-dir

  2. 在应用的根目录下创建一个名为 bin 的文件夹,并将预编译的静态二进制文件放置在此处,我使用 ffmpeg 作为示例。

  3. 在渲染器脚本中使用以下代码:

const approotdir = require('app-root-dir').get();
const ffmpegpath = approotdir + '/bin/ffmpeg';
const spawn = require( 'child_process' ).spawn;
const child = spawn( ffmpegpath, ['-i', inputfile, 'out.mp4']);  //add whatever switches you need here, test on command line first
child.stdout.on( 'data', data => {
    console.log( `stdout: ${data}` );
});
child.stderr.on( 'data', data => {
    console.log( `stderr: ${data}` );
});

这是另一种方法,目前已在 mac 和 windows 上进行了测试。需要“app-root-dir”包,不需要手动添加任何内容到node_modules目录。

  1. 将文件放在 resources/$os/ 下,其中 $os"mac"" linux”,或“win”。构建过程将根据构建目标操作系统从这些目录复制文件。

  2. extrafiles 选项放入您的构建配置中,如下所示:

package.json

"build": {
    "extrafiles": [
      {
        "from": "resources/${os}",
        "to": "resources/bin",
        "filter": ["**/*"]
      }
    ],
  1. 使用类似的方法来确定当前平台。

get-platform.js

import { platform } from 'os';

export default () => {
  switch (platform()) {
    case 'aix':
    case 'freebsd':
    case 'linux':
    case 'openbsd':
    case 'android':
      return 'linux';
    case 'darwin':
    case 'sunos':
      return 'mac';
    case 'win32':
      return 'win';
  }
};
  1. 根据环境和操作系统从您的应用程序调用可执行文件。这里我假设构建版本处于生产模式,源版本处于其他模式,但您可以创建自己的调用逻辑。
import { join as joinPath, dirname } from 'path';
import { exec } from 'child_process';

import appRootDir from 'app-root-dir';

import env from './env';
import getPlatform from './get-platform';

const execPath = (env.name === 'production') ?
  joinPath(dirname(appRootDir.get()), 'bin'):
  joinPath(appRootDir.get(), 'resources', getPlatform());

const cmd = `${joinPath(execPath, 'my-executable')}`;

exec(cmd, (err, stdout, stderr) => {
  // do things
});

我想我使用的是 electron-builder 作为基础,环境文件生成是随之而来的。基本上它只是一个 json 配置文件。

终于介绍完啦!小伙伴们,这篇关于《将预编译的二进制文件捆绑到电子应用程序中》的介绍应该让你收获多多了吧!欢迎大家收藏或分享给更多需要学习的朋友吧~golang学习网公众号也会发布Golang相关知识,快来关注吧!

版本声明
本文转载于:stackoverflow 如有侵犯,请联系study_golang@163.com删除
PHP中的政府网站应用开发指南PHP中的政府网站应用开发指南
上一篇
PHP中的政府网站应用开发指南
PHP华为云API接口对接中的性能优化注意事项与经验分享
下一篇
PHP华为云API接口对接中的性能优化注意事项与经验分享
查看更多
最新文章
查看更多
课程推荐
  • 前端进阶之JavaScript设计模式
    前端进阶之JavaScript设计模式
    设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
    542次学习
  • GO语言核心编程课程
    GO语言核心编程课程
    本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
    511次学习
  • 简单聊聊mysql8与网络通信
    简单聊聊mysql8与网络通信
    如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
    498次学习
  • JavaScript正则表达式基础与实战
    JavaScript正则表达式基础与实战
    在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
    487次学习
  • 从零制作响应式网站—Grid布局
    从零制作响应式网站—Grid布局
    本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
    484次学习
查看更多
AI推荐
  • 千音漫语:智能声音创作助手,AI配音、音视频翻译一站搞定!
    千音漫语
    千音漫语,北京熠声科技倾力打造的智能声音创作助手,提供AI配音、音视频翻译、语音识别、声音克隆等强大功能,助力有声书制作、视频创作、教育培训等领域,官网:https://qianyin123.com
    169次使用
  • MiniWork:智能高效AI工具平台,一站式工作学习效率解决方案
    MiniWork
    MiniWork是一款智能高效的AI工具平台,专为提升工作与学习效率而设计。整合文本处理、图像生成、营销策划及运营管理等多元AI工具,提供精准智能解决方案,让复杂工作简单高效。
    169次使用
  • NoCode (nocode.cn):零代码构建应用、网站、管理系统,降低开发门槛
    NoCode
    NoCode (nocode.cn)是领先的无代码开发平台,通过拖放、AI对话等简单操作,助您快速创建各类应用、网站与管理系统。无需编程知识,轻松实现个人生活、商业经营、企业管理多场景需求,大幅降低开发门槛,高效低成本。
    172次使用
  • 达医智影:阿里巴巴达摩院医疗AI影像早筛平台,CT一扫多筛癌症急慢病
    达医智影
    达医智影,阿里巴巴达摩院医疗AI创新力作。全球率先利用平扫CT实现“一扫多筛”,仅一次CT扫描即可高效识别多种癌症、急症及慢病,为疾病早期发现提供智能、精准的AI影像早筛解决方案。
    178次使用
  • 智慧芽Eureka:更懂技术创新的AI Agent平台,助力研发效率飞跃
    智慧芽Eureka
    智慧芽Eureka,专为技术创新打造的AI Agent平台。深度理解专利、研发、生物医药、材料、科创等复杂场景,通过专家级AI Agent精准执行任务,智能化工作流解放70%生产力,让您专注核心创新。
    190次使用
微信登录更方便
  • 密码登录
  • 注册账号
登录即同意 用户协议隐私政策
返回登录
  • 重置密码