asar 如何解密加密?electron 的 asar 的具体用法

来源:https://newsn.net/say/electron-asar.html

electron中,asar是个特殊的代码格式。asar包里面包含了程序猿编写的代码逻辑。默认情况下,这些代码逻辑,是放置在resource/app目录下面的,明文可见,这样的话,也就有了代码加密(asar打包)的需求

asar 如何解密加密?electron 的 asar 的具体用法(图12-1)

在本篇文章中,苏南大叔将要讲述的内容就是:asar工具的使用。本文的模特是:在mac下面,使用electron-packager简单打包的quick-start项目dmg文件。

基本说明

electron的构建体系中,打包这个概念特别的容易混淆。这里有很多种结果都是可以说是打包,但是打包的程度是完全不同的,这也就决定了不同的打包场景。本文中,asar这个打包,是个最最最最最小的打包概念,而且这个包,仅仅是对resource/app目录的封装,让人们不是那么容易看到你写的代码结果而已。

asar 如何解密加密?electron 的 asar 的具体用法(图12-2)

asar有很多参数,大家可以使用 asar --help来查看其基本参数。当然,如果你使用 asar --help没有反应的话,那么可能您的系统里面还没有全局安装asar,这个时候,你需要下述命令安装一下asar依赖包。

Bash

sudo npm install asar -g

asar 如何解密加密?electron 的 asar 的具体用法(图12-3)

Bash

asar --help

asar 如何解密加密?electron 的 asar 的具体用法(图12-4)

目录结构

提起asar,就应该提起resource目录。这个目录是asar的主战场,里面会有个electron.asar的文件,这个是系统自带的。而如果您的打包命令里面没有指定asar参数的话,你的默认代码目录就会是个app文件夹,而不是app.asar

asar 如何解密加密?electron 的 asar 的具体用法(图12-5)

asar 如何解密加密?electron 的 asar 的具体用法(图12-6)

当然,你可以使用asar命令,把app目录打包成app.asar文件,然后删除app目录。但是这样的话,然并卵,你的最终的文件可能会因此不能正常运行。正确的做法是:你使用electron-packager打包的时候,就必须指定好参数--asar,这样就可以生成个app.asar文件了。

asar 如何解密加密?electron 的 asar 的具体用法(图12-7)

asar 如何解密加密?electron 的 asar 的具体用法(图12-8)

解压app.asar

两条命令任选其一

Bash

asar e app.asar <解压后的目录>
asar extract app.asar <解压后的目录>

我们可以修改 <解压后的目录> 里面的文件,然后,我们再进行打包即可。

asar 如何解密加密?electron 的 asar 的具体用法(图12-9)

asar 如何解密加密?electron 的 asar 的具体用法(图12-10)

打包app.asar

两条命令任选其一,打包asar之后,再看效果。

Bash

asar p <被打包的目录> app.asar
asar pack <被打包的目录> app.asar

asar 如何解密加密?electron 的 asar 的具体用法(图12-11)

asar 如何解密加密?electron 的 asar 的具体用法(图12-12)

结论

asar打包仅仅是个非常初级的加密方式,解密也非常容易。所以,还是把你的代码,使用webpack类似的前端构建工具,进行代码加密混淆,才是正途。


原文地址:https://www.cnblogs.com/xbzhu/p/10663194.html

时间: 2024-10-09 08:52:58

asar 如何解密加密?electron 的 asar 的具体用法的相关文章

WebApi 如何 优雅的 对 输入输出 解密加密

原文:WebApi 如何 优雅的 对 输入输出 解密加密 这不是变态的想法, 这只是对现实需求的转化. 因为有密文, 所以本文不适用于浏览器到服务端的数据交换; 只适用于服务端到服务端的数据传输. 用传统的方法对输入输出做加解密, 无非就是在入口处做操作. 但是 WebApi 的参数如果接收的是一串加密字符串, 那基本上等于和 WebApi 强大的模型绑定 Say baybay 了. 要加解密, 又想利用 WebApi 的便利, 有没有什么好的方法呢? 用 ActionFilter ? Mode

playfair密码解密加密

#include #include #include #include int A[1000][1000];//转化矩阵 int a[1000][1000];//单位矩阵[A E] int B[1000][1000];//矩阵的逆矩阵A^(-1) int ming[1000][1000];//明文矩阵 int mi[1000][1000];//密文矩阵 int n;//矩阵的阶数 void input()//输入数据 { int i, j; for( i = 1; i <= n; i++ ) f

C#对字符串的简单加密解密过程C#的SQL数据库登陆密码的加密解密加密还原直接复制代码使用即可

using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.Security.Cryptography; using System.IO; namespace PDAPrint { class ClassSecurityString { public static string encryptKey = "www.hanma-scan.com"; /

ansible 解密 加密 文件

mac用户可以通过brew命令安装: brew install ansible 首先把密码存在一个固定的文件里,比如  ~/.vault_pass.txt ,方便使用. 如果一个配置文件variables.yml 的内容已经用ansible加密了,如何解密: ansible-vault decrypt --vault-password-file ~/.vault_pass.txt variables.yml 如何加密一个文件: ansible-vault encrypt --vault-pass

重装系统后用!解密加密.exe加密文件怎么給提取出来

BASE64解密加密

package com.mai.base64;import java.io.ByteArrayOutputStream;import java.io.File;import java.io.FileInputStream;import java.io.FileNotFoundException;import java.io.FileOutputStream;import java.io.IOException;import java.io.InputStream; import org.juni

utf-8 解密加密

// 之前的在使用会报警告 urlStr是请求路径 NSString *decodeStr = [urlStr stringByRemovingPercentEncoding];//utf-8解码 NSString *encodeStr = [decodeStr stringByAddingPercentEncodingWithAllowedCharacters:[NSCharacterSet characterSetWithCharactersInString:@"`#%^{}\"[

075_解密加密

https://blog.csdn.net/itsme_web/article/details/81017246 https://blog.csdn.net/itsme_web/article/details/76229260 调用邮件模板 https://blog.csdn.net/itsme_web/article/details/75271801  用apex代码通过Trigger提交审批/在List View上批量提交与审批 button 调用 class https://blog.cs

Electron把网页打包成桌面应用并进行源码加密

前言 最近想把自己用html+css+js做的网页界面打包成桌面应用,网上一搜,发现Electron是一个不错的选择,试了试,发现效果真的不错.这里记录一下打包过程以作记录,便于自己以后查看学习. 一.简介 Electron是由Github开发,用HTML,CSS和JavaScript来构建跨平台桌面应用程序的一个开源库. Electron通过将Chromium和Node.js合并到同一个运行时环境中,并将其打包为Mac,Windows和Linux系统下的应用来实现这一目的. 二.打包过程 1.