【雕爷学编程】Arduino动手做(98)---RC522 RFID射频模块之读写操作及读取UID并将其分别以十进制和十六进制输出到串口

在这里插入图片描述

37款传感器与执行器的提法,在网络上广泛流传,其实Arduino能够兼容的传感器模块肯定是不止这37种的。鉴于本人手头积累了一些传感器和执行器模块,依照实践出真知(一定要动手做)的理念,以学习和交流为目的,这里准备逐一动手尝试系列实验,不管成功(程序走通)与否,都会记录下来—小小的进步或是搞不掂的问题,希望能够抛砖引玉。

【Arduino】168种传感器模块系列实验(资料代码+仿真编程+图形编程)

实验九十八:MFRC-522 RC522 RFID射频 IC卡感应模块读卡器S50复旦卡钥匙扣模组

在这里插入图片描述

Arduino实验接线示意图

在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

【Arduino】168种传感器模块系列实验(资料代码+仿真编程+图形编程)

实验九十八:MFRC-522 RC522 RFID射频 IC卡感应模块读卡器S50复旦卡钥匙扣模组

1、工具-管理库-搜索“MFRC522”库-安装

2、项目二:读取UID,并将其分别以十进制和十六进制输出到串口

实验开源代码之二

/*

【Arduino】168种传感器模块系列实验(资料代码+仿真编程+图形编程)

 实验九十八:MFRC-522 RC522 RFID射频 IC卡感应模块读卡器S50复旦卡钥匙扣模组

1、工具-管理库-搜索“MFRC522”库-安装

2、项目二:读取UID,并将其分别以十进制和十六进制输出到串口

3、RFID与Arduino Uno的连线

SDA------------------------Digital 10

SCK------------------------Digital 13

MOSI----------------------Digital 11

MISO----------------------Digital 12

IRQ------------------------不用连接

GND-----------------------GND

RST------------------------Digital 9           

3.3V------------------------3.3V (千万不要连接到5V接口!!!)

*/



#include <SPI.h>

#include <MFRC522.h>

#define SS_PIN 10

#define RST_PIN 9

MFRC522 rfid(SS_PIN, RST_PIN); //实例化类

// 初始化数组用于存储读取到的NUID 

byte nuidPICC[4];



void setup() { 

 Serial.begin(9600);

 SPI.begin(); // 初始化SPI总线

 rfid.PCD_Init(); // 初始化 MFRC522 

}



void loop() {

 // 找卡

 if ( ! rfid.PICC_IsNewCardPresent())

  return;

 // 验证NUID是否可读

 if ( ! rfid.PICC_ReadCardSerial())

  return;

 MFRC522::ICC_Type piccType = rfid.PICC_GetType(rfid.uid.sak);

 // 检查是否MIFARE卡类型

 if (piccType != MFRC522::ICC_TYPE_MIFARE_MINI &&  

  piccType != MFRC522::ICC_TYPE_MIFARE_1K &&

  piccType != MFRC522::ICC_TYPE_MIFARE_4K) {

  Serial.println("不支持读取此卡类型");

  return;

 }

 // 将NUID保存到nuidPICC数组

 for (byte i = 0; i < 4; i++) {

  nuidPICC = rfid.uid.uidByte;

 }  

 Serial.print("十六进制UID:");

 printHex(rfid.uid.uidByte, rfid.uid.size);

 Serial.println();

 Serial.print("十进制UID:");

 printDec(rfid.uid.uidByte, rfid.uid.size);

 Serial.println();

 // 使放置在读卡区的IC卡进入休眠状态,不再重复读卡

 rfid.PICC_HaltA();

 // 停止读卡模块编码

 rfid.PCD_StopCrypto1();

}

void printHex(byte *buffer, byte bufferSize) {

 for (byte i = 0; i < bufferSize; i++) {

  Serial.print(buffer < 0x10 ? " 0" : "");

  Serial.print(buffer, HEX);

 }

}

void printDec(byte *buffer, byte bufferSize) {

 for (byte i = 0; i < bufferSize; i++) {

  Serial.print(buffer < 0x10 ? " 0" : "");

  Serial.print(buffer, DEC);

 }

}

实验串口返回情况
在这里插入图片描述
实验串口返回情况
在这里插入图片描述

【Arduino】168种传感器模块系列实验(资料代码+仿真编程+图形编程)

实验九十八:MFRC-522 RC522 RFID射频 IC卡感应模块读卡器S50复旦卡钥匙扣模组

1、安装库:IDE-工具-管理库-搜索“MFRC522”库-安装

2、项目三:RC522 模块的读写操作

实验开源代码之三

/*

【Arduino】168种传感器模块系列实验(资料代码+仿真编程+图形编程)

 实验九十八:MFRC-522 RC522 RFID射频 IC卡感应模块读卡器S50复旦卡钥匙扣模组

1、安装库:IDE-工具-管理库-搜索“MFRC522”库-安装

2、项目三:RC522 模块的读写操作

3、RFID与Arduino Uno的连线

SDA------------------------Digital 10

SCK------------------------Digital 13

MOSI----------------------Digital 11

MISO----------------------Digital 12

IRQ------------------------不用连接

GND-----------------------GND

RST------------------------Digital 9           

3.3V------------------------3.3V (千万不要连接到5V接口!!!)

*/

#include <SPI.h>

#include <MFRC522.h>

#define RST_PIN     9      // 配置针脚

#define SS_PIN     10      

MFRC522 mfrc522(SS_PIN, RST_PIN);  // 创建新的RFID实例

MFRC522::MIFARE_Key key;

void setup() {

  Serial.begin(9600); // 设置串口波特率为9600

  while (!Serial);  // 如果串口没有打开,则死循环下去不进行下面的操作

  SPI.begin();    // SPI开始

  mfrc522.PCD_Init(); // Init MFRC522 card

  for (byte i = 0; i < 6; i++) {

    key.keyByte = 0xFF;

  }

  Serial.println(F("扫描卡开始进行读或者写"));

  Serial.print(F("使用A和B作为键"));

  dump_byte_array(key.keyByte, MFRC522::MF_KEY_SIZE);

  Serial.println();

   

  Serial.println(F("注意,会把数据写入到卡在#1"));

}

void loop() {

  // 寻找新卡

  if ( ! mfrc522.PICC_IsNewCardPresent())

    return;

  // 选择一张卡

  if ( ! mfrc522.PICC_ReadCardSerial())

    return;

  // 显示卡片的详细信息

  Serial.print(F("卡片 UID:"));

  dump_byte_array(mfrc522.uid.uidByte, mfrc522.uid.size);

  Serial.println();

  Serial.print(F("卡片类型: "));

  MFRC522:ICC_Type piccType = mfrc522.PICC_GetType(mfrc522.uid.sak);

  Serial.println(mfrc522.PICC_GetTypeName(piccType));

  // 检查兼容性

  if (  piccType != MFRC522:ICC_TYPE_MIFARE_MINI

    && piccType != MFRC522:ICC_TYPE_MIFARE_1K

    && piccType != MFRC522:ICC_TYPE_MIFARE_4K) {

    Serial.println(F("仅仅适合Mifare Classic卡的读写"));

    return;

  }

  // 我们只使用第二个扇区

  // 覆盖扇区4

  byte sector     = 1;

  byte blockAddr   = 4;

  byte dataBlock[]  = {

    0x01, 0x02, 0x03, 0x04, // 1, 2,  3, 4,

    0x05, 0x06, 0x07, 0x08, // 5, 6,  7, 8,

    0x00, 0x00, 0x00, 0x00, // 0,0,0,0

    0x00, 0x00, 0x00, 0x00 // 0,0,0,0

  };//写入的数据定义

  byte trailerBlock  = 7;

  MFRC522::StatusCode status;

  byte buffer[18];

  byte size = sizeof(buffer);

  // 原来的数据

  Serial.println(F("显示原本的数据..."));

  status = (MFRC522::StatusCode) mfrc522.PCD_Authenticate(MFRC522:ICC_CMD_MF_AUTH_KEY_A, trailerBlock, &key, &(mfrc522.uid));

  if (status != MFRC522::STATUS_OK) {

    Serial.print(F("身份验证失败?或者是卡链接失败"));

    Serial.println(mfrc522.GetStatusCodeName(status));

    return;

  }

  // 显示整个扇区

  Serial.println(F("显示所有扇区的数据"));

  mfrc522.PICC_DumpMifareClassicSectorToSerial(&(mfrc522.uid), &key, sector);

  Serial.println();

  // 从块儿读取数据

  Serial.print(F("读取块儿的数据在:")); Serial.print(blockAddr);

  Serial.println(F("块 ..."));

  status = (MFRC522::StatusCode) mfrc522.MIFARE_Read(blockAddr, buffer, &size);

  if (status != MFRC522::STATUS_OK) {

    Serial.print(F("读卡失败,没有连接上 "));

    Serial.println(mfrc522.GetStatusCodeName(status));

  }

  Serial.print(F("数据内容在第 ")); Serial.print(blockAddr); Serial.println(F(" 块:"));

  dump_byte_array(buffer, 16); Serial.println();

  Serial.println();

  //开始进行写入准备

  Serial.println(F("开始进行写入的准备..."));

  status = (MFRC522::StatusCode) mfrc522.PCD_Authenticate(MFRC522:ICC_CMD_MF_AUTH_KEY_B, trailerBlock, &key, &(mfrc522.uid));

  if (status != MFRC522::STATUS_OK) {

    Serial.print(F("写入失败,没有连接上或者没有权限 "));

    Serial.println(mfrc522.GetStatusCodeName(status));

    return;

  }

  // Write data to the block

  Serial.print(F("在第: ")); Serial.print(blockAddr);

  Serial.println(F(" 块中写入数据..."));

  dump_byte_array(dataBlock, 16); Serial.println();

  status = (MFRC522::StatusCode) mfrc522.MIFARE_Write(blockAddr, dataBlock, 16);

  if (status != MFRC522::STATUS_OK) {

    Serial.print(F("写入失败... "));

    Serial.println(mfrc522.GetStatusCodeName(status));

  }

  Serial.println();

  // 再次读取卡中数据,这次是写入之后的数据

  Serial.print(F("读取写入后第")); Serial.print(blockAddr);

  Serial.println(F(" 块的数据 ..."));

  status = (MFRC522::StatusCode) mfrc522.MIFARE_Read(blockAddr, buffer, &size);

  if (status != MFRC522::STATUS_OK) {

    Serial.print(F("读取失败... "));

    Serial.println(mfrc522.GetStatusCodeName(status));

  }

  Serial.print(F("块 ")); Serial.print(blockAddr); Serial.println(F("数据为 :"));

  dump_byte_array(buffer, 16); Serial.println();

     

  // 验证一下数据,要保证写入前后数据是相等的

  // 通过计算块中的字节数量

  Serial.println(F("等待验证结果..."));

  byte count = 0;

  for (byte i = 0; i < 16; i++) {

    // 比较一下缓存中的数据(我们读出来的数据) = (我们刚刚写的数据)

    if (buffer == dataBlock)

      count++;

  }

  Serial.print(F("匹配的字节数量 = ")); Serial.println(count);

  if (count == 16) {

    Serial.println(F("验证成功 :"));

  } else {

    Serial.println(F("失败,数据不匹配"));

    Serial.println(F("也许写入的内容不恰当"));

  }

  Serial.println();

     

  // 转储扇区数据

  Serial.println(F("写入后的数据内容为::"));

  mfrc522.PICC_DumpMifareClassicSectorToSerial(&(mfrc522.uid), &key, sector);

  Serial.println();

  // 停止 PICC

  mfrc522.PICC_HaltA();

  //停止加密PCD

  mfrc522.PCD_StopCrypto1();

}

/**

* 将字节数组转储为串行的十六进制值

*/

void dump_byte_array(byte *buffer, byte bufferSize) {

  for (byte i = 0; i < bufferSize; i++) {

    Serial.print(buffer < 0x10 ? " 0" : " ");

    Serial.print(buffer, HEX);

  }

}

实验串口返回情况
在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

  • 1
    点赞
  • 19
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

驴友花雕

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值