lm959680 发表于 2012-3-26 18:44:01

NXP RC522开发套件【转载】

本帖最后由 lm959680 于 2012-3-26 18:45 编辑

先下手为强,后下手遭殃~~~ {:victory:} 不是打广告啊·~~别乱说!


但有一点 商业的建议尽量升级但也不用反映太大 想破_解不是说就能说出来的,关键还有免费茶等着!~



从以上卡片简介中大家可以明显看到PLUS CPU卡片具有很突出的优点,我们再一次
归纳一下为什么要选择PLUS CPU卡片来代替MIFARE Classic 卡片的最主要原因:
l安全可靠性:PLUSCPU卡片是真正CPU卡片,安全级别与CPU卡相同,通信
及数据更加安全可靠;
l卡片兼容性:PLUS CPU卡片向下兼容MIFARE Classic(S50、S70),可对原采
用MIFARE Classic 卡片的系统进行无缝升级;
l操作简易性:PLUS CPU卡片存储结构与MIFARE Classic 相同,采用扇区(块)
数据格式,对卡片的操作方法一致,大大减少重新了解卡片的时间;
l性价比高:PLUS CPU卡片与MIFARE Classic 卡片价格相差不大,对整个系统的
升级成本影响不大


RC522开发套件

xxtt 发表于 2012-3-26 20:44:39

看看 ................

黑暗深处 发表于 2012-3-26 20:52:24

一般的应用不需要CPU卡吧?
M1卡足够了,现在国内公交一卡通很多都是M1卡,非专业人员基本上都很难破解
现在用125K卡做门禁的也还很多,所以现在大量应用的还是M1卡
另外卡片的COS也是一个问题,这些都是额外的成本

如果是学习智能卡还是建议用RC632,支持SPI,并口,可以读写ISO14443/A/B ISO15693

wolegequ 发表于 2012-3-26 20:55:17

小弟最近在做RC522 遇到一个问题 望指教现在是用MFRC522能够认证M1卡 但是读取的时候没有反应 大侠们看会是什么问题?

wolegequ 发表于 2012-3-26 20:58:43

/////////////////////////////////////////////////////////////////////          这个是我用的认证函数
//功    能:验证卡片密码
//参数说明: auth_mode: 密码验证模式
//               0x60 = 验证A密钥
//               0x61 = 验证B密钥
//          addr:块地址
//          pKey:密码
//          pSnr:卡片序列号,4字节
//返    回: 成功返回MI_OK
/////////////////////////////////////////////////////////////////////               
char PcdAuthState(unsigned char auth_mode,unsigned char addr,unsigned char *pKey,unsigned char *pSnr)
{
    char status;
    unsigned intunLen;
    unsigned char i,ucComMF522Buf;

    ucComMF522Buf = auth_mode;
    ucComMF522Buf = addr;
    for (i=0; i<6; i++)
    {    ucComMF522Buf = *(pKey+i);   }
    for (i=0; i<4; i++)
    {    ucComMF522Buf = *(pSnr+i);   }
   
    status = PcdComMF522(PCD_AUTHENT,ucComMF522Buf,12,ucComMF522Buf,&unLen);
    if ((status != MI_OK) || (!(ReadRawRC(Status2Reg) & 0x08)))
//   if ((status != MI_OK))
    {   status = MI_ERR;   }
   ClearBitMask(Status2Reg,0x08);
    return status;
}


/*************************RC522和ISO14443卡通讯函数 *************************
**功    能:通过RC522和ISO14443卡通讯
**参数说明:Command:RC522命令字
**          pInData:通过RC522发送到卡片的数据
**          InLenByte:发送数据的字节长度
**          pOutData:接收到的卡片返回数据
**          *pOutLenBit:返回数据的位长度
********************************************************************************/
char PcdComMF522(unsigned char Command,
               unsigned char *pInData,
               unsigned char InLenByte,
               unsigned char *pOutData,
               unsigned int*pOutLenBit)
{
    char status = MI_ERR;
    unsigned char errorflag;
    unsigned char irqEn   = 0x00;
    unsigned char waitFor = 0x00;
    unsigned char lastBits;
    unsigned char n;
    unsigned int i;
    switch (Command)
    {
       case PCD_AUTHENT:
          irqEn   = 0x12;
          waitFor = 0x10;
          break;
       case PCD_TRANSCEIVE:
          irqEn   = 0x77;
          waitFor = 0x30;
          break;
       default:
         break;
    }
      
    WriteRawRC(ComIEnReg,irqEn|0x80);
    ClearBitMask(ComIrqReg,0x80);
    WriteRawRC(CommandReg,PCD_IDLE);
    SetBitMask(FIFOLevelReg,0x80);
      
    for (i=0; i<InLenByte; i++)
    {   WriteRawRC(FIFODataReg, pInData);    }
      WriteRawRC(CommandReg, Command);
      if (Command == PCD_TRANSCEIVE)
    {
      SetBitMask(BitFramingReg,0x80);
    }
    i = 5000;
    do
    {
         n = ReadRawRC(ComIrqReg);
         i--;
    } while ((i!=0) && !(n&0x01) && !(n&waitFor));//0x00110000
    errorflag = ReadRawRC(ErrorReg);
    ClearBitMask(BitFramingReg,0x80);

   
    if (i!=0)
    {   
         //if(!(ReadRawRC(ErrorReg)&0x1B))
          if(!(errorflag&0x1B))
         {
             status = MI_OK;
             if (n & irqEn & 0x01)
             {   status = MI_NOTAGERR;   }
             if (Command == PCD_TRANSCEIVE)
             {
                       n = ReadRawRC(FIFOLevelReg);                     //FIFO 中的字节数目
                    lastBits = (ReadRawRC(ControlReg) & (0x07));   //如果为0 则接受到的字节有效
                if (lastBits)
                {   *pOutLenBit = (n-1)*8 + lastBits;   }
                else
                {   *pOutLenBit = n*8;   }
                if (n == 0)
                {   n = 1;    }
                if (n > MAXRLEN)
                {   n = MAXRLEN;   }
                for (i=0; i<n; i++)
                {   pOutData = ReadRawRC(FIFODataReg);    }
            }
         }
         else
         {   status = MI_ERR;   }
      
   }
   

   SetBitMask(ControlReg,0x80);         // stop timer now
   WriteRawRC(CommandReg,PCD_IDLE);
   return status;
}



主函数是这样的:
status_findcard = PcdRequest(PICC_REQIDL,tt1);   //find cards
if(status_findcard == 0)
{
      GPIOF->BRR= (GPIO_Pin_6 | GPIO_Pin_7 | GPIO_Pin_8 | GPIO_Pin_9);
}
else
{
   
    GPIOF->BSRR= (GPIO_Pin_6 | GPIO_Pin_7 | GPIO_Pin_8 | GPIO_Pin_9);
}
   status_anticoll = PcdAnticoll(sn); /**/    //防冲突
if(status_anticoll == 0)
{
      status_selectcard = PcdSelect(sn , &size1);    //select a card and read the size
      
}

status_auth = PcdAuthState(0x60 , 0x08 , key , sn );   //验证                验证返回正确值
   
   status_read =PcdRead(0x08,block);       //read a block         但是读取返回失败

}


请各位大侠指点 多谢

wolegequ 发表于 2012-3-26 21:00:28

/////////////////////////////////////////////////////////////////////
//功    能:读取M1卡一块数据
//参数说明: addr:块地址
//          pData:读出的数据,16字节
//返    回: 成功返回MI_OK
/////////////////////////////////////////////////////////////////////
char PcdRead(unsigned char addr,unsigned char *pData)
{
    char status;
    unsigned intunLen;
    unsigned char i,ucComMF522Buf;

    ucComMF522Buf = PICC_READ;
    ucComMF522Buf = addr;
    CalulateCRC(ucComMF522Buf,2,&ucComMF522Buf);
   
      
    status = PcdComMF522(PCD_TRANSCEIVE,ucComMF522Buf,4,ucComMF522Buf,&unLen);
   //status = PcdComMF522(PCD_TRANSCEIVE,ucComMF522Buf,2,ucComMF522Buf,&unLen);
   
    if ((status == MI_OK) && (unLen == 0x90))
    {
      for (i=0; i<16; i++)
      {    *(pData+i) = ucComMF522Buf;   }
    }
    else
    {   status = MI_ERR;   }
   
    return status;
}

wolegequ 发表于 2012-3-26 21:07:17

附件中 复位函数中没有对TxAutoReg进行操作就不对啊      
LZ这个资料有没有试过啊 对不对啊

smilelb 发表于 2012-5-11 01:47:33

黑暗深处 发表于 2012-3-26 20:52 static/image/common/back.gif
一般的应用不需要CPU卡吧?
M1卡足够了,现在国内公交一卡通很多都是M1卡,非专业人员基本上都很难破解
现 ...

632与522的pcd与picc通信函数应该是一样的吧。。。我这里632中的PcdComTranseive();函数跟522中PcdComMF522();中的逻辑不一样,会不会是632官方源代码有问题呢?谢谢~

chtxzy 发表于 2012-7-2 15:57:18

mark比较好,谢谢分享

huxiaoping 发表于 2012-7-5 01:45:13

这玩意啥东西啊,一点价值都没有

wsh 发表于 2012-7-19 13:59:28

mark                                 

lpandadp 发表于 2012-7-29 15:40:48

{:smile:}{:smile:}{:smile:}{:smile:}{:smile:}{:smile:}{:smile:}

z903057128 发表于 2012-8-9 17:46:27

毕业正进入这一行 有资料就收 感谢楼主

luoguangqi 发表于 2012-9-3 09:30:41

MARK!!!

jacky_shen 发表于 2012-9-29 10:50:21

RC522开发套件,里面的源代码有问题的

miaoxun206 发表于 2012-10-23 11:13:17

了解                     

flyxiao 发表于 2013-1-30 15:48:24

不错的资料
可以看看

sundayzh 发表于 2013-2-1 19:09:36

有点小问题

Hz01800475 发表于 2013-2-18 11:02:56

学习。。。

zndz410 发表于 2013-3-6 16:44:14

可以看看

WYK 发表于 2013-8-26 20:54:21

学习学习

songjie 发表于 2013-10-15 16:52:55

{:smile:} 学习学习

zzjxfc 发表于 2013-12-26 11:20:35

{:smile:}{:3_41:}

worldsing 发表于 2014-2-10 13:46:29

有用RC522操作的么

peter_yu 发表于 2014-3-26 13:47:03

感谢分享!

zhcj66 发表于 2014-5-17 14:54:03

学习了{:lol:}

huangqilin14 发表于 2014-5-22 11:18:39

顶下,强大

jaky80000 发表于 2014-7-7 12:04:27

学习,谢谢楼主

lnso 发表于 2014-7-15 12:33:01

wolegequ 发表于 2012-3-26 21:00
/////////////////////////////////////////////////////////////////////
//功    能:读取M1卡一块数据
/ ...

大侠,你的门禁弄成功了没??

cadre 发表于 2014-7-16 08:31:02

mark{:smile:}

sml009 发表于 2015-11-18 09:40:53

学习了,

kyle4812 发表于 2017-2-7 17:47:42

看看,谢谢分享
页: [1]
查看完整版本: NXP RC522开发套件【转载】