其实个人感觉还是代码重要,因为不读卡,哪里来的防冲突,其实防冲突讲了这么多实现起来也就是一个函数

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);