Skip to main content

Universal Radio Hacker: investigate wireless protocols like a boss

Project description

Universal Radio Hacker Blackhat Arsenal 2017

Tests Linux/OSX Tests Windows Test Coverage Latest Release
Build Status Build status Coverage Status PyPI version

The Universal Radio Hacker (URH) is a software for investigating unknown wireless protocols. Features include

  • hardware interfaces for common Software Defined Radios
  • easy demodulation of signals
  • assigning participants to keep overview of your data
  • customizable decodings to crack even sophisticated encodings like CC1101 data whitening
  • assign labels to reveal the logic of the protocol
  • fuzzing component to find security leaks
  • modulation support to inject the data back into the system
  • simulation environment to perform stateful attacks

To get started, download the official userguide (PDF), watch the demonstration videos (YouTube) or check out the wiki for more information and supported devices. Scroll down this page to learn how to install URH on your system.

Want to stay in touch? Slack

If you find URH useful, please consider giving this repository a :star: or even donate via PayPal. We appreciate your support!

Installation

Universal Radio Hacker can be installed via pip or using the package manager of your distribution (if included). Below you find more specific installation instructions for:

Windows

On Windows, URH can be installed with it's MSI Installer. No further dependencies are required.

If you get an error about missing api-ms-win-crt-runtime-l1-1-0.dll, run Windows Update or directly install KB2999226.

Linux

Via Package Manager

For the following linux distributions you can install URH using your package manager.

Distribution Install with
Arch Linux yaourt -S urh
Gentoo / Pentoo emerge -av urh
Fedora 25+ dnf install urh
openSUSE zypper install urh

Generic way with pip (Ubuntu/Debian)

URH you can also be installed with pip using pip3 install urh. In case you are running Ubuntu or Debian read on for more specific instructions.

In order to use native device backends, make sure you install the -dev package for your desired SDRs, that is libairspy-dev, libhackrf-dev, librtlsdr-dev , libuhd-dev .

If your device does not have a -dev package, e.g. LimeSDR, you need to manually create a symlink to the .so, like this:

sudo ln -s /usr/lib/x86_64-linux-gnu/libLimeSuite.so.17.02.2 /usr/lib/x86_64-linux-gnu/libLimeSuite.so

before installing URH, using:

sudo apt-get update
sudo apt-get install python3-numpy python3-psutil python3-zmq python3-pyqt5 g++ libpython3-dev python3-pip
sudo pip3 install urh

Docker Image

If you use docker you can also run the official URH docker image available here.

Mac OS X

  1. Install Python 3 for Mac OS X. If you experience issues with preinstalled Python, make sure you update to a recent version using the given link.
  2. (Optional) Install desired native libs e.g. brew install librtlsdr for corresponding native device support.
  3. In a terminal, type: pip3 install urh.
  4. Type urh in a terminal to get it started.

Update your installation

Updating with Pip

If you installed URH via pip you can keep it up to date with pip3 install --upgrade urh, or, if this should not work python3 -m pip install --upgrade urh.

Updating with MSI

If you experience issues after updating URH using the .msi installer on Windows, please perform a full uninstallation. That is, uninstall URH via Windows and after that remove the installation folder (something like C:\Program Files\Universal Radio Hacker). Now, install the new version using the recent .msi .

Running from source

If you like to live on bleeding edge, you can run URH from source.

Without installation

To execute the Universal Radio Hacker without installation, just run:

git clone https://github.com/jopohl/urh/
cd urh/src/urh
./main.py

Note, before first usage the C++ extensions will be built.

Installing from source

To install from source you need to have python-setuptools installed. You can get it e.g. with pip install setuptools. Once the setuptools are installed use:

git clone https://github.com/jopohl/urh/
cd urh
python setup.py install

And start the application by typing urh in a terminal.

External decodings

See wiki for a list of external decodings provided by our community! Thanks for that!

Screenshots

Get the data out of raw signals

Interpretation phase

Keep an overview even on complex protocols

Analysis phase

Record and send signals

Record

Project details


Release history Release notifications | RSS feed

Download files

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

Source Distribution

urh-2.2.0.tar.gz (2.9 MB view details)

Uploaded Source

Built Distributions

urh-2.2.0-cp36-cp36m-win_amd64.whl (10.6 MB view details)

Uploaded CPython 3.6m Windows x86-64

urh-2.2.0-cp36-cp36m-win32.whl (8.9 MB view details)

Uploaded CPython 3.6m Windows x86

urh-2.2.0-cp35-cp35m-win_amd64.whl (10.6 MB view details)

Uploaded CPython 3.5m Windows x86-64

urh-2.2.0-cp35-cp35m-win32.whl (8.9 MB view details)

Uploaded CPython 3.5m Windows x86

File details

Details for the file urh-2.2.0.tar.gz.

File metadata

  • Download URL: urh-2.2.0.tar.gz
  • Upload date:
  • Size: 2.9 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? No

File hashes

Hashes for urh-2.2.0.tar.gz
Algorithm Hash digest
SHA256 1aa54a0a3cd29ddfb91a9b5a09890f20429c731fd25414f3262ddef79e556d33
MD5 d7564439488694f214fb02d5016a4f45
BLAKE2b-256 8c60656da24f60bce991c48aa6ac6aa0c741345a91dc354618661ce907a76850

See more details on using hashes here.

File details

Details for the file urh-2.2.0-cp36-cp36m-win_amd64.whl.

File metadata

File hashes

Hashes for urh-2.2.0-cp36-cp36m-win_amd64.whl
Algorithm Hash digest
SHA256 881585f3192c8b2a4d9bc31a1e7f05b0528a01da028fcb045b9f4e84b9479733
MD5 e3130b7408943bbeda0bee778d6881c6
BLAKE2b-256 778a3644f85fd7cea5ab688122b818e134b9d341e675d45f44c560bdb7fd9faa

See more details on using hashes here.

File details

Details for the file urh-2.2.0-cp36-cp36m-win32.whl.

File metadata

File hashes

Hashes for urh-2.2.0-cp36-cp36m-win32.whl
Algorithm Hash digest
SHA256 77d15ffcf346cc5f2878e47657e5389ef8d7cba6bbe70559ae36402784916e99
MD5 b568018d71cbdae5289561ef419c2771
BLAKE2b-256 bf2ebf92d42a3a26c2b29e260c82f95f3f73f347c59fb0ee68ef6ccd9c9e71d7

See more details on using hashes here.

File details

Details for the file urh-2.2.0-cp35-cp35m-win_amd64.whl.

File metadata

File hashes

Hashes for urh-2.2.0-cp35-cp35m-win_amd64.whl
Algorithm Hash digest
SHA256 667e788836e35bba01c9bda08ce432373696c359358589d53e661d01b0094561
MD5 6a7067afdea83eb20d5dc12e75acc34d
BLAKE2b-256 6883734f7bdf00105467c0d9f81db906a5c6fd545e7c9c8982b1d468468fedee

See more details on using hashes here.

File details

Details for the file urh-2.2.0-cp35-cp35m-win32.whl.

File metadata

File hashes

Hashes for urh-2.2.0-cp35-cp35m-win32.whl
Algorithm Hash digest
SHA256 b709ca6126dbfc7ec519fa0b0bb0a1c58b124c039b2e3465bb69603ea4ebfb69
MD5 0a00835d51fe3955804684d7dec96b75
BLAKE2b-256 84577fad60a8ff2f87e7d75b82b0bbbb8faf81e65efa31e6b1eeb7e313a5c1ee

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