A powerful obfuscator for JavaScript and Node.js
demo : obfuscator.io
fork from : https://github.com/javascript-obfuscator/javascript-obfuscator.git

sanex3339 c20239be58 added const 9 years ago
dist c20239be58 added const 9 years ago
src c20239be58 added const 9 years ago
tests af7e8e14ef dev 9 years ago
typings d250696dc7 typings update 9 years ago
.gitignore c17464ee6c 0.2.1 9 years ago
.npmrc a2806cabc9 dev 9 years ago
index.ts 632e02fc55 IOptions interface 9 years ago
package.json dda6b03edf version 0.5.1 9 years ago
readme.md dda6b03edf version 0.5.1 9 years ago
tsconfig.json 0e126bc1a4 moved js files to dist dir 9 years ago
tslint.json 651d846230 dev 9 years ago
typings.json de40546d94 refactoring 9 years ago

readme.md

#JavaScript obfuscator for Node.js

JavaScript obfuscator for Node.js and free alternative of js-obfuscator (which uses javascriptobfuscator.com) without any limits and sending data on server. Compatible with ES6. Tested on Angular2 bundle. https://gist.github.com/sanex3339/ffc2876123b52e6d11ce45369fd53acf

###Installation

Install the package with NPM and add it to your devDependencies:

npm install --save-dev javascript-obfuscator

###Usage:

var JavaScriptObfuscator = require('javascript-obfuscator');

var obfuscatedCode = JavaScriptObfuscator.obfuscate(
    `
    (function(){
        var variable = 'abc';
        console.log(variable);
    })();
    `,
    {
        rotateUnicodeArray: false
    }
);

console.log(obfuscatedCode);
/*
var _0x8741 = [
    '\u0061\u0062\u0063',
    '\u006c\u006f\u0067'
];
(function () {
    var _0x45e59c = _0x8741[0];
    console[_0x8741[1]](_0x45e59c);
}());
*/

obfuscate(sourceCode, options)

###sourceCode Type: string Default: null

Any valid SourceCode

###options Type: Object Default: null

Options for JavaScript obfuscator:

{
    rotateUnicodeArray: true
    // ...
}

###Available options ####compact Type: boolean Default: true

Compact code output in one line.

####debugProtection Type: boolean Default: false

#####This option can cause browser freeze while Developer Tools is enabled! Use at own risk.

Force enable debug mode in some browsers (mainly based on WebKit) on page load, if Developers Tools panel is enbaled. With this options using of Debug panel is impossible.

WebKit based browsers: blocking site window, but you still can navigate through Developers Tools panel. Firefox: not blocking site window, but you still can't use Debug panel.

####debugProtectionInterval Type: boolean Default: false

#####This option can cause browser freeze even while Developer Tools is disabled! Use at own risk.

Works if debugProtection is enabled.

Force enable debug mode in some browsers (mainly based on WebKit) when Developers Tools panel was enbaled, even after page was loaded.

####disableConsoleOutput Type: boolean Default: true

Disable console.log, console.info, console.error and console.warn messages output into browser console.

####rotateUnicodeArray Type: boolean Default: true

For more hard understanding of code, during each obfuscation all literal values are stored in array as Unicode codes sequence. This options will rotate all values inside array on a random value during obfuscation of code, and insert inside source code helper function which will rotate array values back to their original indexes.

This option affected only on visual code organisation, because we can easily get original array during debug process.

Not recommended for small source code, because helper function will attract attention.

####wrapUnicodeArrayCalls Type: boolean Default: true

Instead using direct calls to unicodeArray items var t = _0x43a123[0x0], when index 0x0 can be easy reverted to 0 with few js beautifiers, this option wrap all calls to special function instead.

var t = _0x12a634('0x0')