Skip to main content

Universal Radio Hacker: investigate wireless protocols like a boss

Project description

Linux Build Status Windows Build status OSX Build Status PyPI version Coverage Status Slack Blackhat Arsenal 2017

The Universal Radio Hacker 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

Check out the wiki for more information and supported devices.

Like to see things in action? Watch URH on YouTube!

Youtube Image

Want to stay in touch? Join our Slack Channel!

Support the development: Donate

Installation

Universal Radio Hacker can be installed via pip or using the package manager of your distribution (if included). Furthermore, you can install urh from source or run it without installation directly from source. Below you find more specific installation instructions for: - Linux - Windows - Mac OS X

Dependencies

Required

Optional

Python 3.4+

librtlsdr (for native RTL-SDR support)

python-numpy

libhackrf (for native HackRF support)

python-psutil

libairspy (for native AirSPy support)

python-zmq

liblimesdr (for native LimeSDR support)

PyQt5

libuhd (for native USRP suppport)

C++ Compiler

libsdrplay (for native SDRplay support)

rfcat (for RfCat plugin to send e.g. with YardStick One)

gnuradio / gnuradio-osmosdr (for GNU Radio device backends)

Linux

Via Package Manager

If you run any of the following linux distributions you can easily 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

If your distribution does not provide a package for URH you can install it using pip3 install urh. Below you find more detailed instruction for Ubuntu/Debian.

Ubuntu/Debian

If you want 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

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.

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

Uploaded Source

Built Distributions

urh-1.9.1-cp36-cp36m-win_amd64.whl (8.8 MB view details)

Uploaded CPython 3.6m Windows x86-64

urh-1.9.1-cp36-cp36m-win32.whl (8.5 MB view details)

Uploaded CPython 3.6m Windows x86

urh-1.9.1-cp35-cp35m-win_amd64.whl (8.8 MB view details)

Uploaded CPython 3.5m Windows x86-64

urh-1.9.1-cp35-cp35m-win32.whl (8.5 MB view details)

Uploaded CPython 3.5m Windows x86

File details

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

File metadata

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

File hashes

Hashes for urh-1.9.1.tar.gz
Algorithm Hash digest
SHA256 78b09c44eaa1a175cc25677a916c6390f896f1b78adcc7528991651655182fca
MD5 b9e8ca1273900d3453e41a26eabd9cc8
BLAKE2b-256 0af76a6d5666c01a4d7817198b8051b1215b0e2f03c19f7dff06a0a773bb07c1

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for urh-1.9.1-cp36-cp36m-win_amd64.whl
Algorithm Hash digest
SHA256 5d1dfb7a8cdcbf360a31db92e95533a50c24dc0a972ff146ac5f73c6fcce9921
MD5 5216dd6c50d9003f3af6033c9386108c
BLAKE2b-256 7f927e58d2acb9a2f715fba6f1893c531b8ed913f3a55c5b27fd2331e1e13cd2

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for urh-1.9.1-cp36-cp36m-win32.whl
Algorithm Hash digest
SHA256 93bc1191a9c8f65cc740ca7763f5d60b8cd0348610918c34da46bdb645e678a0
MD5 b54c8d5f0a4ea0c8db80b4379cb4c381
BLAKE2b-256 1ade5b6506f7aa677bf415489438f959267c25c25e081a1a20586df7ca4e7beb

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for urh-1.9.1-cp35-cp35m-win_amd64.whl
Algorithm Hash digest
SHA256 ed488ab9a73ba027741d63dc5981e5d94ee92f0d085784642d30971e70ee0337
MD5 51c181a7cbc63bacf5d51164bfe57533
BLAKE2b-256 fc5def0d2785ca026c7c460f39e3e0da15cf517260ab811f10b1fcc35f3d1efa

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for urh-1.9.1-cp35-cp35m-win32.whl
Algorithm Hash digest
SHA256 e0e003d92a2cf07e2a3250a76e40ee7324d2dc47b869eb5efc81222cafcc1cdc
MD5 b163f3f84d9db26fb649684ec531c8e8
BLAKE2b-256 62897fbd16e7003274f4883238fff915a9be1ebe689087b142186cfd62d5e787

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