.. note:: Hello, welcome to the SunFounder Raspberry Pi & Arduino & ESP32 Enthusiasts Community on Facebook! Dive deeper into Raspberry Pi, Arduino, and ESP32 with fellow enthusiasts. **Why Join?** - **Expert Support**: Solve post-sale issues and technical challenges with help from our community and team. - **Learn & Share**: Exchange tips and tutorials to enhance your skills. - **Exclusive Previews**: Get early access to new product announcements and sneak peeks. - **Special Discounts**: Enjoy exclusive discounts on our newest products. - **Festive Promotions and Giveaways**: Take part in giveaways and holiday promotions. 👉 Ready to explore and create with us? Click [|link_sf_facebook|] and join today! 2.2.7 MFRC522 RFID Module ========================== Introduction --------------- Radio Frequency Identification (RFID) refers to technologies that use wireless communication between an object (or tag) and interrogating device (or reader) to automatically track and identify such objects. Some of the most common applications for this technology include retail supply chains, military supply chains, automated payment methods, baggage tracking and management, document tracking and pharmaceutical management, to name a few. In this project, we will use RFID for reading and writing. Components ---------- .. image:: img/list_2.2.7.png Principle --------- **RFID** Radio Frequency Identification (RFID) refers to technologies that involve using wireless communication between an object (or tag) and an interrogating device (or reader) to automatically track and identify such objects. The tag transmission range is limited to several meters from the reader. A clear line of sight between the reader and tag is not necessarily required. Most tags contain at least one integrated circuit (IC) and an antenna. The microchip stores information and is responsible for managing the radio frequency (RF) communication with the reader. Passive tags do not have an independent energy source and depend on an external electromagnetic signal, provided by the reader, to power their operations. Active tags contain an independent energy source, such as a battery. Thus, they may have increased processing, transmission capabilities and range. .. image:: img/image230.png **MFRC522** MFRC522 is a kind of integrated read and write card chip. It is commonly used in the radio at 13.56MHz. Launched by the NXP Company, it is a low-voltage, low-cost, and small-sized non-contact card chip, a best choice of intelligent instrument and portable handheld device. The MF RC522 uses advanced modulation and demodulation concept which fully presented in all types of 13.56MHz passive contactless communication methods and protocols. In addition, it supports rapid CRYPTO1 encryption algorithm to verify MIFARE products. MFRC522 also supports MIFARE series of high-speed non-contact communication, with a two-way data transmission rate up to 424kbit/s. As a new member of the 13.56MHz highly integrated reader card series, MF RC522 is much similar to the existing MF RC500 and MF RC530 but there also exists great differences. It communicates with the host machine via the serial manner which needs less wiring. You can choose between SPI, I2C and serial UART mode (similar to RS232), which helps reduce the connection, save PCB board space (smaller size), and reduce cost. Schematic Diagram ----------------- .. image:: img/image331.png Experimental Procedures ----------------------- **Step 1:** Build the circuit. .. image:: img/image232.png :width: 800 **Step 2:** Set up SPI (refer to :ref:`spi_configuration` for more details. If you have set SPI, skip this step.) For C Language Users ^^^^^^^^^^^^^^^^^^^^ **Step 3:** Go to the folder of the code. .. raw:: html .. code-block:: cd ~/davinci-kit-for-raspberry-pi/c/2.2.7/ **Step 4:** Compile the code. .. raw:: html .. code-block:: make read make write .. note:: There are two examples for you to read or write the card ID, and you can choose one of them according to your need. **Step 5:** Run the executable file. .. raw:: html .. code-block:: sudo ./read .. raw:: html .. code-block:: sudo ./write .. note:: If it does not work after running, or there is an error prompt: \"wiringPi.h: No such file or directory\", please refer to :ref:`install_wiringpi`. **Code Explanation** .. code-block:: c InitRc522(); This function is used to initialize the RFID RC522 module. .. code-block:: c uint8_t read_card_data(); This function is used to read the data of the card, and if the read is successful, it will return "1". .. code-block:: c uint8_t write_card_data(uint8_t *data); This function is used to write the data of card and returns "1" if the write is successful. \*data is the information that will be written to the card. For Python Language Users ^^^^^^^^^^^^^^^^^^^^^^^^^ **Step 2**: Activating the Virtual Environment. .. note:: * Before activation, you need to ensure that you have created a virtual environment, please refer to: :ref:`create_virtual`. * Each time you restart the Raspberry Pi, or open a new terminal, you will need to run the following command again to activate the virtual environment. .. raw:: html .. code-block:: shell source myenv/bin/activate Once the virtual environment is activated, you will see the environment name before the command line prompt, indicating you are working within the virtual environment. **Step 3:** Install the libraries. The ``spidev`` library helps handle interactions with the SPI and is a key component to this tutorial as we need it for the Raspberry Pi to interact with the RFID RC522. Run the following command to install ``spidev`` to your Raspberry Pi via ``pip``. .. raw:: html .. code-block:: sudo pip3 install spidev Continue to install the MFRC522 library. The MFRC522 library contains two files: ``MFRC522.py`` and ``SimpleMFRC522.py``. Among them ``MFRC522.py`` is the realization of RFID RC522 interface, this library handles all the heavy work of communicating with RFID through Pi's SPI interface. ``SimpleMFRC522.py`` takes the ``MFRC522.py`` file and greatly simplifies it by allowing you to deal with only a few functions instead of a few functions. .. raw:: html .. code-block:: sudo pip3 install mfrc522 **Step 4**: Exiting the Virtual Environment. When you have completed your work and wish to exit the virtual environment, simply run: .. raw:: html .. code-block:: shell deactivate This will return you to the system's global Python environment. **Step 5:** Go to the folder of the code. .. raw:: html .. code-block:: cd ~/davinci-kit-for-raspberry-pi/python/2.2.7 **Step 6:** Run the executable file. .. raw:: html .. code-block:: sudo python3 2.2.7_read.py .. raw:: html .. code-block:: sudo python3 2.2.7_write.py .. note:: * After running ``2.2.7_read.py``, it will print the ``id`` and ``text`` of your card in the shell. * After running ``2.2.7_write.py``, you need to write a message first, press ``Enter`` to confirm, and finally put your card on the MFRC522 RFID module to finish writing. **code** .. note:: You can **Modify/Reset/Copy/Run/Stop** the code below. But before that, you need to go to source code path like ``davinci-kit-for-raspberry-pi/python``. .. raw:: html .. code-block:: python # read import time from mfrc522 import SimpleMFRC522 import RPi.GPIO as GPIO reader = SimpleMFRC522() def main(): while True: print("Reading...Please place the card...") id, text = reader.read() print("ID: %s\nText: %s" % (id,text)) time.sleep(3) def destroy(): GPIO.cleanup() if __name__ == '__main__': try: main() # When 'Ctrl+C' is pressed, the program destroy() will be executed. except KeyboardInterrupt: destroy() .. raw:: html .. code-block:: python # write from mfrc522 import SimpleMFRC522 import RPi.GPIO as GPIO reader = SimpleMFRC522() def main(): while True: text = input('Please write new data:') print("Please place the card to complete writing") reader.write(text) print("Data writing is complete") def destroy(): GPIO.cleanup() if __name__ == '__main__': try: main() # When 'Ctrl+C' is pressed, the program destroy() will be executed. except KeyboardInterrupt: destroy() **Code Explanation** .. code-block:: python reader = SimpleMFRC522() Instantiate ``SimpleMFRC522()`` class. .. code-block:: python reader.read() This function is used to read card data. If the reading is successful, id and text will be returned. .. code-block:: python reader.write(text) This function is used to write information to the card, press ``Enter`` key to finish writing. ``text`` is the information to be written to the card. Phenomenon Picture --------------------- .. image:: img/image233.jpeg