基于Stm32的RFID-RC522模块的对RFID读写使用

    RFID-RC522是一个淘宝上比较常见的一个识别RFID的一个模块。他可以做到对RFID的读写。     MF RC522 是应用于13.56MHz 非接触式通信中高集成度读写卡系列芯片中的一员。是NXP公司针对“三表”应用推出的一款低电压、低成本、体积小的非接触式读写卡芯片,是智能仪表和便携 式手持设备研发的较好选择

##RFID读写卡的过程     读写卡主要有五个步骤:寻卡,防冲突,选卡,认证,读/写卡。 ###寻卡

// REQ_ALL代表寻天线区内所有卡,TagType为返回的卡的类型
status= PcdRequest( REQ_ALL , TagType );

TagType返回的卡类型有: 0x4400 = Mifare_UltraLight 0x0400 = Mifare_One(S50) 0x0200 = Mifare_One(S70) 0x0800 = Mifare_Pro(X) 0x4403 = Mifare_DESFire ###防冲突

if(!status)
{
	status = PcdAnticoll(SelectedSnr);
	// ......
}

###认证

if(!status)
{
	// 认证
	snr = 1;    // 扇区号1
	status = PcdAuthState(KEYA, (snr*4+3), DefaultKey, SelectedSnr);    // 校验1扇区密码,密码位于每一扇区第3块
	// ......
}

四个参数分别是:验证A密钥,块地址,扇区密码,卡序列号 ###读写卡

if(!status)
{
	//读写卡
	status = PcdRead((snr*4+0), buf);   // 读卡,读取1扇区0块数据到buf[0]-buf[16]
	status = PcdWrite((snr*4+0), "way2");   // 写卡,将buf[0]-buf[16]写入1扇区0块
	if(!status) 
	{
		//读写成功
		printf("read finish!\n");
		printf("读到的值是: %s\n",buf);
		WaitCardOff();
	}
}

##代码 以下为核心代码: main.c

#include "stm32f10x.h"
#include "delay.h"
#include "bsp_usart.h"
#include "RC522.h"

int main()
{
    char status;
	unsigned char snr, buf[16], TagType[2], SelectedSnr[4], DefaultKey[6] = {0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF};
    
    delay_init();
    usart_init();
    
    PcdInit();
	PcdReset();
	PcdAntennaOff();
	PcdAntennaOn();
	M500PcdConfigISOType( 'A' );

    printf( "init over!\n" );
	while(1){
        // 寻卡
		status= PcdRequest( REQ_ALL , TagType );    // REQ_ALL代表寻天线区内所有卡。TagType为返回的卡类型
		if(!status)
		{
            // 防冲突
			status = PcdAnticoll(SelectedSnr);
			if(!status)
			{
                // 选卡
				status=PcdSelect(SelectedSnr);
				if(!status)
				{
                    // 认证
					snr = 1;    // 扇区号1
					status = PcdAuthState(KEYA, (snr*4+3), DefaultKey, SelectedSnr);    // 校验1扇区密码,密码位于每一扇区第3块
                                          // 验证A密钥,块地址,扇区密码,卡序列号
					{
						if(!status)
						{
                            //读写卡
							status = PcdRead((snr*4+0), buf);   // 读卡,读取1扇区0块数据到buf[0]-buf[16]
//							status = PcdWrite((snr*4+0), "way2");   // 写卡,将buf[0]-buf[16]写入1扇区0块
							if(!status) 
							{
                                //读写成功
                                printf("read finish!\n");
                                printf("读到的值是: %s\n",buf);
								WaitCardOff();
							}
						}
					}
				}
			}
		}
	}
}

RC522.h

#ifndef __RC522_H
#define __RC522_H

#define MF522_RST_PIN                    GPIO_Pin_11
#define MF522_RST_PORT                   GPIOB
#define MF522_RST_CLK                    RCC_APB2Periph_GPIOB

#define MF522_MISO_PIN                   GPIO_Pin_10
#define MF522_MISO_PORT                  GPIOB
#define MF522_MISO_CLK                   RCC_APB2Periph_GPIOB

#define MF522_MOSI_PIN                   GPIO_Pin_1
#define MF522_MOSI_PORT                  GPIOB
#define MF522_MOSI_CLK                   RCC_APB2Periph_GPIOB

#define MF522_SCK_PIN                    GPIO_Pin_0
#define MF522_SCK_PORT                   GPIOB
#define MF522_SCK_CLK                    RCC_APB2Periph_GPIOB

#define MF522_NSS_PIN                    GPIO_Pin_7
#define MF522_NSS_PORT                   GPIOA
#define MF522_NSS_CLK                    RCC_APB2Periph_GPIOA

#define RST_H                            GPIO_SetBits(MF522_RST_PORT, MF522_RST_PIN)
#define RST_L                            GPIO_ResetBits(MF522_RST_PORT, MF522_RST_PIN)
#define MOSI_H                           GPIO_SetBits(MF522_MOSI_PORT, MF522_MOSI_PIN)
#define MOSI_L                           GPIO_ResetBits(MF522_MOSI_PORT, MF522_MOSI_PIN)
#define SCK_H                            GPIO_SetBits(MF522_SCK_PORT, MF522_SCK_PIN)
#define SCK_L                            GPIO_ResetBits(MF522_SCK_PORT, MF522_SCK_PIN)
#define NSS_H                            GPIO_SetBits(MF522_NSS_PORT, MF522_NSS_PIN)
#define NSS_L                            GPIO_ResetBits(MF522_NSS_PORT, MF522_NSS_PIN)
#define READ_MISO                        GPIO_ReadInputDataBit(MF522_MISO_PORT, MF522_MISO_PIN)

// 函数原型
void PcdInit(void);
char PcdReset(void);
void PcdAntennaOn(void);
void PcdAntennaOff(void);
char PcdRequest(unsigned char req_code,unsigned char *pTagType);
char PcdAnticoll(unsigned char *pSnr);
char PcdSelect(unsigned char *pSnr);
char PcdAuthState(unsigned char auth_mode,unsigned char addr,unsigned char *pKey,unsigned char *pSnr);
char PcdRead(unsigned char addr,unsigned char *pData);
char PcdWrite(unsigned char addr,unsigned char *pData);
char PcdValue(unsigned char dd_mode,unsigned char add
  • 24
    点赞
  • 169
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
STM32F103是一款基于ARM Cortex-M3内核的32位微控制器,RC522是一款无线射频(RF)读写模块。下面是一个关于STM32F103与RC522模块进行测试的例程: 首先,我们需要准备好硬件。将RC522模块连接至STM32F103的相应引脚,如SDA连接至STM32的SPI1的MOSI引脚,SCK连接至SPI1的SCK引脚,RST连接至STM32的GPIO引脚等。 然后,我们需要在STM32F103中配置SPI接口,使其能够与RC522模块进行通信。我们可以使用STM32的库函数来完成这一步骤。首先,需要初始化SPI1,设置数据传输速率、MSB传输顺序等参数。接下来,需要设置RC522的复位引脚为输出引脚,并将其拉高,用于复位RC522模块。然后,我们可以通过SPI接口与RC522进行通信,发送命令、接收响应等。 在测试例程中,我们可以通过发送不同的命令,如取卡片ID、写入数据到卡片等,与RC522进行交互。通过检查RC522的响应,我们可以确定通信是否成功。另外,我们还可以设置RC522的工作模式,如RFID模式或MIFARE模式等,以及相关的参数,如接收功率、通信速率等。 最后,在测试例程中,我们还可以通过STM32F103的UART接口,将RC522取到的卡片信息,如卡片ID或卡片数据,发送至PC机或其他外设,用于进一步处理或显示。 综上所述,通过上述步骤,我们可以进行STM32F103与RC522模块的测试。在实际应用中,可以根据具体需求,扩展更多的功能和测试项,以实现更加复杂的应用场景。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值