Pyarmor

Pyarmor is a command line tool used to import or run obfuscated python scripts. Only by a few extra files, pyarmor can run and imported obfuscated files as normal python scripts.

Pyarmor just likes an enhancement which let python could run or import obfuscated files.

Main Features

Obfuscation Mechanism

Pyarmor obfuscates python scripts by 2 ways:

More information refer to How to obfuscate python scripts

Support Platforms

Quick Start

Installation

The simple way is pip

    pip install pyarmor

Or get source package from pypi/pyarmor

Pyarmor is a command line tool, main script is pyarmor.py. After you get source package, unpack it to any path, then run paramor.py as common python script

    python pyarmor.py

If Pyarmor is installed by pip, there is a command will be avaiable in Python script path

    pyarmor

Basic Usage

The following examples show how to obfuscate a python package pybench, which locates in the examples/pybench in the source of pyarmor.

Obfuscate package pybench directly:

    python pyarmor.py obfuscate --src examples/pybench --entry pybench.py \
                                "*.py" "package/*.py"

    # Note that quotation mark is required for file patterns, otherwise
    # it will be expanded base on current path by shell.
    #
    # This command will create an extra file .pyarmor_capsule.zip in the
    # --src path, and save all the obfuscated scripts to default output
    # path "dist" in the current path
    #
    cd dist

    # Check obfuscated script
    cat pybench.py

    # Run obfuscated script
    python pybench.py

Use project to manage obfuscated scripts:

    mkdir projects
    python pyarmor.py init --src examples/pybench --entry pybench.py \
                           projects/pybench

    # This command will create 2 files: .pyarmor_config, .pyarmor_capsule.zip
    # in the project path "projects/pybench"
    cd projects/pybench

    # And there is a shell script "pyarmor" is created at the same time.
    # (In windows, the name is "pyarmor.bat")
    #
    # Now run command "build" to obfuscated all the scripts
    #
    ./pyarmor build

    # Check obfuscated script
    cd dist
    cat pybench.py

    # Run obfuscated script
    python pybench.py

There is a webui used to manage project easily. Start it

    # For windows
    src/webui/manager.bat

    # For linux
    src/webui/manager.sh
    
    # If Pyarmor is installed by pip
    pyarmor-webui

Here is online demo http://pyarmor.dashingsoft.com

More information, refer to https://github.com/dashingsoft/pyarmor

Any question feel free email to jondy.zhao@gmail.com