在Vite中使用rollup-plugin-obfuscator进行代码混淆,主要是在构建(build)阶段进行配置。以下是根据您的提示,分步骤说明如何在Vite项目中配置rollup-plugin-obfuscator: 1. 确定Vite构建配置文件的位置 Vite的构建配置文件通常是项目根目录下的vite.config.ts或vite.config.js文件。 2. 安装rollup-plugin-obfuscator 首先,...
安装插件 yarn add --dev rollup-plugin-javascript-obfuscator 创建obfuscator.js文件,把下面相应代码放入js文件中 importobfuscatorPluginfrom'rollup-plugin-javascript-obfuscator';exportfunctioncodeObfuscatorPlugin(isBuild) {if(!isBuild) {return[]; }constcodeObfuscator = { ...obfuscatorPlugin({rotateUnicodeArra...
build: { rollupOptions: { // 确保外部化处理那些你不想打包进库的依赖 external: ['vue', 'jquery'], output: { // 在 UMD 构建模式下为这些外部化的依赖提供一个全局变量 globals: { vue: 'Vue', jquery: '$' } }, plugins: [ obfuscator({ compact: true, controlFlowFlattening: true, control...
使用rollup插件:如果你使用的是Rollup作为Vite的打包工具,你可以尝试使用rollup-plugin-obfuscator等插件来混淆你的代码,以防止敏感信息泄露。这些插件可以对生成的代码进行混淆和重命名,以减少可读性并防止潜在的信息泄露。 // vite.config.js import obfuscator from 'rollup-plugin-obfuscator'; export default { build...
yarn add --dev rollup-plugin-javascript-obfuscator 1. 创建obfuscator.js文件,把下面相应代码放入js文件中 import obfuscatorPlugin from 'rollup-plugin-javascript-obfuscator'; export function codeObfuscatorPlugin(isBuild) { if (!isBuild) { return []; ...
obfuscator.js也有对应 webpack 的 plugin 和 rollup(vite打包用的就是rollup) 的 plugin 实现起来比较简单,如有需要也可以自己找符合要求的plugin或者自己写一个,本质上就是把这个文件的执行过程自动追加到打包过程中 */ const JavaScriptObfuscator = require('javascript-obfuscator') ...
Thank you very much for your reply, I tried switching to the rollup pluginrollup-plugin-obfuscatorand it seems to work fine. https://www.npmjs.com/package/rollup-plugin-obfuscator importObfusticatorfrom'rollup-plugin-obfuscator'vite:({command})=>({plugins:[command==="serve"?[]:Obfusticator...
首先导入javascript-obfuscator,并修改vite.config.js(或.ts)配置文件如下: import { defineConfig } from 'vite';import vue from '@vitejs/plugin - vue';import JavaScriptObfuscator from 'javascript - obfuscator';export default defineConfig({plugins: [vue()],build: {rollupOptions: {output: {plugins:...
Uglify / Obfuscator: 通过对 JS 代码进行丑化和混淆,尽可能降低其可读性。 Native 加密: 通过XOR 或 AES 对构建产物进行加密,封装到 Node Addon 中,并在运行时由 JS 解密。 ASAR 加密: 将Electron ASAR 文件进行加密,并修改 Electron 源代码,在读取 ASAR 文件之前对其解密后再运行。 V8 字节码: 通过Node 标...
import postcss from 'rollup-plugin-postcss'; export default { build: { sourcemap: false, rollupOptions : { plugins : [ postcss({ modules: { generateScopedName: "[hash:base64:8]", }, autoModules: true, }), obfuscator ( { transformObjectKeys : true, unicodeEscapeSequence : true, numberTo...