最近这两天在忙这个rfid的模块,首要我供认,自己是菜鸟,渠道是依据初学者入门的51单片机,可是我仍是总结一下最近这两天看代码的收成
读卡器的软件规划:看Pdf文档如同现已给出来了了,可是初学者的话,了解也好好久,这儿我晒出datasheet中的规划流程,在结合代码剖析,到达能够识别出卡片的作用
首要如同是复位应对,依据datasheet的阐明,讲的是MIFARE射频卡的通讯协议和通讯的波特率是界说好的,当有卡进入读卡器的操作规模时,读卡器就会以特定的协议与他进行通讯,判别进入的卡片是否是MIFARE射频卡
其实datasheet上这段话如同看起来很吊,但实际上却给人一种摸不到脑筋的感觉,其实,看了代码才知道,软件上的刘晨叫初始化,要对读卡器进行一次软件复位,并设定读卡器的作业方式
这儿的代码是:
PcdReset();//rc522初始化
PcdAntennaOff(); //封闭天线
PcdAntennaOn(); //翻开天线
M500PcdConfigISOType( ‘A’ );//设定作业形式
第二过程是防抵触,datasheet里边讲:当有多张卡进入读卡器的感应规模的时分,防抵触机制就会发动,主动从多张卡中进行操作,之后如同有一大堆的话,讲怎么样防抵触
其实个人感觉仍是代码重要,由于不读卡,哪里来的防抵触,其实防抵触讲了这么多完成起来也便是一个函数
status = PcdRequest(PICC_REQALL, g_ucTempbuf);
//PICC_REQALL他是个宏界说 意思是寻觅天线内的一切卡片,
// g_ucTempbuf 是个数组,在这儿函数读取卡内的前两位放在数组中
status = PcdAnTIcoll(g_ucTempbuf);//防抵触
这儿有点意思的是,有的时分要实施判别卡的品种,这儿有个片段,应该能够用到程序上去
判别卡的品种,判别读卡的时分回来的第一位数据,其他的函数用的是12864的,这儿咱们不必去深究
//有卡则判别是什么卡,然后显现在液晶上
// 0x4400 = Mifare_UltraLight
// 0x0400 = Mifare_One(S50)
// 0x0200 = Mifare_One(S70)
// 0x0800 = Mifare_Pro(X)
// 0x4403 = Mifare_DESFire
switch(g_ucTempbuf[0])
{
case 0x44:
ck12864_com(0x93);
for(i=0;i《10;i++)
{
ck12864_data(leixing1[i]);
}
break;
case 0x02:
ck12864_com(0x93);
for(i=0;i《8;i++)
{
ck12864_data(leixing2[i]);
}
break;
case 0x04:
ck12864_com(0x93);
for(i=0;i《8;i++)
{
ck12864_data(leixing3[i]);
}
break;
case 0x08:
ck12864_com(0x93);
for(i=0;i《6;i++)
{
ck12864_data(leixing4[i]);
}
break;
}
接下来便是流程3,选中卡片,对卡片进行操作,依据datasheet,被选中的卡的序列码,并一起回来卡的容量:
代码完成:
status = PcdSelect(g_ucTempbuf);
流程4,也便是对选中的卡片进行操作,首要进行暗码的核实,这儿包含读写操作
代码的完成,也是两句话:
status = PcdAuthState(PICC_AUTHENT1A, 5, DefaultKey, g_ucTempbuf);
if (status != MI_OK)
{ conTInue; }
//写数据到块
status = PcdWrite(5, data1);
if (status != MI_OK)
{ conTInue; }
//读一块数据
流程5:将卡片处于休眠状况:
PcdHalt();
这5过程能够完成对卡片的具体操作的流程,现在咱们经过刷卡操控步进电机,其实能够省掉过程4
假如做一个不记名的刷卡,也便是没有绑定特定的卡号的开门,现在就能够完成了
示例代码:
#include
#include“mian.h”
#include“rc522.h”
typedef unsigned int uint;
typedef unsigned char uchar;
uchar status;
uchar g_ucTempbuf[20];
void main()
{
uint i;
//初始化:
PcdReset();//rc522初始化
PcdAntennaOff(); //封闭和翻开天线
PcdAntennaOn();
M500PcdConfigISOType(‘A’);//设定作业形式
//防抵触,这儿需求一个循环,让读卡器不断去读卡
while(1)
{
status = PcdRequest(PICC_REQALL, g_ucTempbuf);
//PICC_REQALL他是个宏界说 意思是寻觅天线内的一切卡片,
// g_ucTempbuf 是个数组,在这儿函数读取卡内的前两位放在数组中
if(status != MI_OK)//没有找到卡,持续履行PcdRequest()
{
conTInue;
}
status = PcdAnticoll(g_ucTempbuf);//防抵触
//卡片序列号,4字节,这儿的status能够判PcdAnticoll的履行情况
//假如履行成功,表明g_ucTempbuf上面现已记在仅有的卡号了
//在这儿g_ucTempbuf现已用了2+4个
if(status != MI_OK)//没有找到卡,持续履行PcdRequest()
{
continue;
}
PcdHalt();
if(status == MI_OK)
{
LED_GREEN =0;
for(i=0;i《125;i++)
{
step();
}
LED_GREEN = 1;
}
}
}
void DelayMs(unsigned int _MS)
{
TH1 = (unsigned char)(RCAP2_1ms》》8);
TL1 = (unsigned char)(RCAP2_1ms);
ET1 = 0; // Disable timer2 interrupt
来历;21ic