Skip to main content

Python library for interfacing with MIFARE RFID card readers using mifarepy protocol

Project description

mifarepy

PyPI Version Python Versions PyPI Downloads License GitHub Issues

Overview

mifarepy is a Python library for interfacing with MIFARE® RFID card readers (e.g., PROMAG PCR310U, MF5, MF10) using the GNetPlus® protocol. It provides a clean, object-oriented API for performing common operations such as:

  • Interacting via RS232 and USB-serial interfaces
  • Supporting GNetPlus® commands (Read, Write, Authenticate, Auto Mode, etc.)
  • Reading a card’s serial number (get_sn, wait_for_card)
  • Querying reader firmware version (get_version)
  • Enabling/disabling automatic card events (set_auto_mode, wait_for_card)
  • Authenticating sectors (authenticate_sector)
  • Reading and writing 16‑byte blocks (read_block, write_block)
  • Bulk operations on sectors and arbitrary block mappings (read_sector, write_sector, read_blocks, write_blocks)

Attribution & Original Repository

This project is derived from the original gnetplus.py which is written in Python 2 by Chow Loong Jin & Harish Pillay.

  • Original Repository: gnetplus by harishpillay
  • Original Authors: Chow Loong Jin & Harish Pillay
  • License: This project remains under LGPL v3.0 or later to comply with the original licensing terms.

This version of gnetplus.py includes bug fixes, more features, documentation improvements, and enhanced compatibility.


Supported Hardware

This library is compatible with PROMAG MIFARE® readers, including:

  • PCR310U (USB-based)
  • MF5 OEM Read/Write Module
  • MF10 MIFARE Read/Write Module
  • Other devices using the GNetPlus® protocol

These readers operate at 13.56 MHz and support MIFARE® 1K/4K, Ultra-Light, and PRO cards.


Installation

To install mifarepy, ensure Python 3.6+ is installed, then run:

pip install mifarepy

Or manually include the mifarepy.py file in your project.


Quickstart

from mifarepy.reader import MifareReader

# Initialize the reader on your serial port
reader = MifareReader('/dev/ttyUSB0')

# Enable auto mode and wait for card detection
reader.set_auto_mode(True)
card_sn = reader.wait_for_card(timeout=10)
print('Found card:', card_sn)

# Authenticate sector 1 with the default Key A
default_key = bytes.fromhex('FFFFFFFFFFFF')
reader.authenticate_sector(sector=1, key=default_key, key_type='A')

# Read block 4 and display as hex
block_data = reader.read_block(4)
print('Block 4 data:', block_data)

# Write 16 bytes to block 4
payload = bytes(range(16))
reader.write_block(4, payload)

Communicating with the Reader

Detecting the Device

When plugged into a Linux system (such as Raspberry Pi or Fedora), the reader is detected as:

Prolific Technology, Inc. PL2303 Serial Port

To find the assigned port, check:

dmesg | grep ttyUSB

Example output:

usb 6-1: pl2303 converter now attached to ttyUSB3

This means the device is at /dev/ttyUSB3.


Supported Commands

This library supports the following GNetPlus® protocol commands:

Command Functionality
Polling Check if a reader is connected
Get Version Retrieve firmware version
Logon/Logoff Secure access
Get Serial Number Retrieve MIFARE® card serial number
Read Block Read memory block from MIFARE® 1K card
Write Block Write to a specific block
Authenticate Perform authentication with Key A/Key B
Set Auto Mode Enable/Disable automatic event notifications
Request All Detect multiple cards in the field

For a full list of commands, refer to the * *mifarepy Communication Protocol**.


Example Output

When a card is detected, you will see:

Found card: 0x19593d65
Tap card again.
Found card: 0x19593d65

If no card is found, the script prompts:

Tap card again.

MIFARE® 1K Card Structure

The MIFARE® 1K card consists of 16 sectors, each with 4 blocks (16 bytes each).
Memory layout:

  • Blocks 0-3: Sector 0 (First block stores manufacturer data)
  • Blocks 4-7: Sector 1
  • Blocks 8-11: Sector 2
  • ...
  • Blocks 60-63: Sector 15 (Contains access keys & conditions)

For authentication, use Key A or Key B stored in the last block of each sector.


MIFARE® 1K Authentication & Security

  1. Authenticate before reading/writing.
  2. Use GNetPlus SAVE_KEY command to store keys securely.
  3. Blocks are protected by access conditions.
  4. Keys should not be stored in the same sector as sensitive data.

For further details, refer to:


License

This project is licensed under GNU Lesser General Public License v3.0 or later (LGPL-3.0-or-later).
See COPYING for full details.


Documentation & References

For more details, refer to:

For further information, visit: GIGA-TMS Inc.


Author & Credits

Original Authors:

Adapted & Maintained by:


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

mifarepy-2.0.tar.gz (18.0 kB view details)

Uploaded Source

Built Distribution

mifarepy-2.0-py3-none-any.whl (14.3 kB view details)

Uploaded Python 3

File details

Details for the file mifarepy-2.0.tar.gz.

File metadata

  • Download URL: mifarepy-2.0.tar.gz
  • Upload date:
  • Size: 18.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.8.18

File hashes

Hashes for mifarepy-2.0.tar.gz
Algorithm Hash digest
SHA256 5b43755089f99772c287142746c7e172a6fe32ee04838a0f26040d29b9f1aa01
MD5 94cb386793c17170af90201a9c8ffbb2
BLAKE2b-256 d87eeeeeb4d79849e055442122c41a79adf7f399640d271af72ba803749de5b7

See more details on using hashes here.

File details

Details for the file mifarepy-2.0-py3-none-any.whl.

File metadata

  • Download URL: mifarepy-2.0-py3-none-any.whl
  • Upload date:
  • Size: 14.3 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.8.18

File hashes

Hashes for mifarepy-2.0-py3-none-any.whl
Algorithm Hash digest
SHA256 54aecfbe6b93e7b51f154a325e2b1f09dc522100abec6457e44f55bcd8097828
MD5 d49bf35181fc4df604c029376a4dba8a
BLAKE2b-256 40c9feb88f293c4d68a977f8d44bc514c1be574c5f09a7fae4de708dc569c7d8

See more details on using hashes here.

Supported by

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