Skip to content
/ nxppy Public
forked from svvitale/nxppy

Python wrapper for interfacing with the NXP EXPLORE-NFC shield for Raspberry Pi

License

Notifications You must be signed in to change notification settings

arthurv/nxppy

This branch is 31 commits ahead of, 148 commits behind svvitale/nxppy:master.

Folders and files

NameName
Last commit message
Last commit date

Latest commit

3d8e904 · Jan 29, 2015

History

31 Commits
Jun 15, 2014
Oct 3, 2014
Nov 16, 2014
Jun 14, 2014
Jun 15, 2014
Nov 16, 2014
Nov 16, 2014
Jan 29, 2015
Oct 5, 2014
Jan 29, 2015

Repository files navigation

nxppy

nxppy is a very simple Python wrapper for interfacing with the excellent NXP EXPLORE-NFC shield for the Raspberry Pi. It takes NXP's Public Reader Library and provides a thin layer for detecting a Mifare RFID tag, reading its UID (unique identifier), and reading/writing data from/to the user area.

This was based very heavily on NXP's card_polling example code. The example code was only reorganized to be more conducive as an interface. NXP still retains full copyright and ownership of the example code. All files outside of the NXP directory are distributed under the MIT license.

Compatibility

Tested with both Python 2.7 (as installed on Raspberry Pi) and with a manually compiled version of Python 3.4.

Requirements

You'll need to run these commands and install these packages to build nxppy:

sudo apt-get install python2.7-dev
sudo apt-get install cmake

The NXP-EXPLORE card relies on SPI being enabled. The setup script will automatically enable it and load the kernel module if it's not enabled/loaded already.

Installation

nxppy is available from pypi. Simply run:

sudo pip install nxppy

Source

To install from source, use distutils:

sudo apt-get install python-setuptools
sudo python setup.py build install

Usage

Currently, the module supports only Mifare cards:

import nxppy

mifare = nxppy.Mifare()

# Select the first available tag and return the UID
uid = mifare.select()

# Read 16 bytes starting from block 10 
# (each block is 4 bytes, so technically this reads blocks 10-13)
block10bytes = mifare.read_block(10)

# Write a single block of 4 bytes
mifare.write_block(10, b'abcd')

Feedback

I welcome your feedback and pull requests! This project started as a necessity for my own Raspberry Pi development, but I'm hoping others will find it useful as a way to quickly bootstrap NFC-based projects. Enjoy!

About

Python wrapper for interfacing with the NXP EXPLORE-NFC shield for Raspberry Pi

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages

  • C 86.9%
  • C++ 9.6%
  • Objective-C 3.3%
  • Python 0.2%