Skip to main content

Analysis tool for estimating the likelihood that a binary contains compressed or encrypted bytes

Project description

Bintropy Tweet

Detect packers on PE/ELF/Mach-O files using entropy.

PyPi Python Versions Build Status DOI License

This tool is an implementation in Python of Bintropy, an analysis tool presented in this paper in the scope of packing detection based on entropy. It implements both modes of operation and an additional one, respectively on the entire binary, per section or per segment. It uses the entropy values mentioned in the paper for deciding whether the binary contains compressed/encrypted bytes.

It relies on lief for abstracting either PE, ELF or Mach-O executables. This tool thus supports these three formats.

$ pip install bintropy
$ bintropy --help

Modes of operation

Use the -m/--mode option.

  • 0: full binary (default)
  • 1: per section
  • 2: per segment

Note that mode 2 will logically give results very similar to mode 0.

$ bintropy binary
<<< boolean >>>

$ bintropy binary --dot-not-decide
<<< highest block entropy, average block entropy >>>
$ bintropy binary --mode [1|2]
<<< boolean >>>

$ bintropy binary -m [1|2] --do-not-decide
<<< highest block entropy, average block entropy >>>

Benchmarking

Use the -b/--benchmark option to get one more value, the processing time in seconds.

$ bintropy binary -b
<<< boolean, processing time >>>

$ bintropy binary -b --do-not-decide
<<< highest block entropy, average block entropy, processing time >>>

Overriding default entropy values

The reference paper uses 6.677 for the average block entropy and 7.199 for the highest block entropy (obtained by analyzing a dataset of PE files and using the first mode of operation). These values can be overriden with the dedicated options.

$ bintropy binary --threshold-average-entropy 5.678 --threshold-highest-entropy 6.789
[...]

Plotting

This tool features plot generation for drawing binary's sections and the entropy within.

$ bintropy binary --plot
<<< boolean >>>

Example of generated figures:

Related Projects

You may also like these:

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

bintropy-1.5.7.tar.gz (186.9 kB view details)

Uploaded Source

Built Distribution

bintropy-1.5.7-py3-none-any.whl (39.7 kB view details)

Uploaded Python 3

File details

Details for the file bintropy-1.5.7.tar.gz.

File metadata

  • Download URL: bintropy-1.5.7.tar.gz
  • Upload date:
  • Size: 186.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.11.7

File hashes

Hashes for bintropy-1.5.7.tar.gz
Algorithm Hash digest
SHA256 98de18115affda73a41d83157f28d20e95c0a624559f7c34d298043650f86a87
MD5 e4bbf72a837b8c428f811070f3ff2c58
BLAKE2b-256 931678ee9c761c3021df1c9c86062e3f8b2db6096d4b54003060222998ed1b09

See more details on using hashes here.

File details

Details for the file bintropy-1.5.7-py3-none-any.whl.

File metadata

  • Download URL: bintropy-1.5.7-py3-none-any.whl
  • Upload date:
  • Size: 39.7 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.11.7

File hashes

Hashes for bintropy-1.5.7-py3-none-any.whl
Algorithm Hash digest
SHA256 9d974407c616b2c4ccb38c93b5a0531156273b68e9d85c08d23edafd24114e3d
MD5 228bd8c0997fc19e55737e723afcd926
BLAKE2b-256 2bc21ebcf2da87dc7cfbbc3240166609be735c953234322042d8194c534dff08

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page