Skip to main content

Universal Radio Hacker: investigate wireless protocols like a boss

Project description

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

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: - Linux - Via Package Manager - Generic way with pip (Ubuntu/Debian) - Windows - MSI Installer - Pip - Mac OS X - Updating your installation - Updating with Pip - Updating with MSI - Running from source

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

Windows

MSI Installer

The easiest way to install URH on Windows is to use the .msi installer available here.

It is recommended to use the 64 bit version of URH because native device support is not available on 32 bit windows. If you get an error about missing api-ms-win-crt-runtime-l1-1-0.dll, run Windows Update or directly install KB2999226.

Pip

If you run Python 3.4 on Windows you need to install Visual C++ Build Tools 2015 first.

It is recommended to use Python 3.5 or later on Windows, so no C++ compiler needs to be installed.

  1. Install Python 3 for Windows. Choose a 64 Bit Python version for native device support.

  2. In a terminal, type: pip install urh.

  3. Type urh in a terminal or search for urh in search bar to start the application.

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!

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.0.2.tar.gz (8.4 MB view details)

Uploaded Source

Built Distributions

If you're not sure about the file name format, learn more about wheel file names.

urh-2.0.2-cp36-cp36m-win_amd64.whl (9.2 MB view details)

Uploaded CPython 3.6mWindows x86-64

urh-2.0.2-cp36-cp36m-win32.whl (8.8 MB view details)

Uploaded CPython 3.6mWindows x86

urh-2.0.2-cp35-cp35m-win_amd64.whl (9.2 MB view details)

Uploaded CPython 3.5mWindows x86-64

urh-2.0.2-cp35-cp35m-win32.whl (8.8 MB view details)

Uploaded CPython 3.5mWindows x86

File details

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

File metadata

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

File hashes

Hashes for urh-2.0.2.tar.gz
Algorithm Hash digest
SHA256 40740699cae8d9e3ee5b346cdeff6003ebdd8389e07b76c635fbc397d788d99b
MD5 2b4ce750a8ead9b8982eea9a4709ef5d
BLAKE2b-256 b7a0c2047a52a8ffa847bcbf6c70fb5f07578ba88a27bf1f85ecc671e46a0b12

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for urh-2.0.2-cp36-cp36m-win_amd64.whl
Algorithm Hash digest
SHA256 0445032e05c8b4eb190f252754327f19531cf06db54bef5fab511ed1d711e047
MD5 45c6ac8c38f72a0c649b83d7732f659f
BLAKE2b-256 f984e162c8e4f9a353531f5e881c2a97d2e4b003c5dc1432164d6d53bc03acec

See more details on using hashes here.

File details

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

File metadata

  • Download URL: urh-2.0.2-cp36-cp36m-win32.whl
  • Upload date:
  • Size: 8.8 MB
  • Tags: CPython 3.6m, Windows x86
  • Uploaded using Trusted Publishing? No

File hashes

Hashes for urh-2.0.2-cp36-cp36m-win32.whl
Algorithm Hash digest
SHA256 663033bee71fc6df1bde4044be58d93b6a206f3dec5ff74af2015df44c324390
MD5 43e2759718c1c48066dc5a7b695c3aa9
BLAKE2b-256 73ccb3284bb19a28b4f38d2a0ed7cb42315f3509600d393721a868ab90a99dd7

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for urh-2.0.2-cp35-cp35m-win_amd64.whl
Algorithm Hash digest
SHA256 8208a8a1b0b838501ba6f4f3864c15d3450cf90fd6212f5d48cb1e247e877078
MD5 5e0672302b15704e555cf2668e6cee6b
BLAKE2b-256 0915ff0fb0e37b0e25069b6561796ae5eb2dd819b2b8f55f150e909089d58608

See more details on using hashes here.

File details

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

File metadata

  • Download URL: urh-2.0.2-cp35-cp35m-win32.whl
  • Upload date:
  • Size: 8.8 MB
  • Tags: CPython 3.5m, Windows x86
  • Uploaded using Trusted Publishing? No

File hashes

Hashes for urh-2.0.2-cp35-cp35m-win32.whl
Algorithm Hash digest
SHA256 c0e4bcdd7eb00bf58516228d164ebe97833113bfd0678570a6502c8a8a6e69d0
MD5 7ab4e9ebe85555be35754a1958f9b7aa
BLAKE2b-256 de3b96c0d5ff1f7dde56440f8cc1820083932eb02b9c5af173c29d163be26f78

See more details on using hashes here.

Supported by

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