找回密码
 立即注册

QQ登录

只需一步,快速开始

搜索
查看: 2297|回复: 1
打印 上一主题 下一主题
收起左侧

水控单机版rc5224.16一个密码版

[复制链接]
跳转到指定楼层
楼主
ID:405893 发表于 2018-10-7 09:22 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
可以参考一下,keil代码。
RC522在STC89C52上开发实例
STC-ISP V39.exe下载就不会擦出eeprom,STC_ISP_V479.exe下载会将eeprom擦出

单片机源程序如下:
  1. /****************************************Copyright (c)**************************************************
  2. M1卡使用情况:
  3. 1.卡号对应不同人员
  4. 2.块号1存放该人员可进入的区域编号,从第一字节表示区域编号为1,

  5. 3.如果通过,则红灯亮,否则,不亮。
  6. 4.每次刷卡,RC522上传卡号以及块号1内容到上位机           
  7. ********************************************************************************************************/

  8. #include "STC12C54xx.h"        
  9. #include "eeprom.h"
  10. #include "mfrc522.h"  
  11. //uchar code data1[16] ={0x12,0x34,0x56,0x78,0xED,0xCB,0xA9,0x87,0x12,0x34,0x56,0x78,0x01,0xFE,0x01,0xFE};

  12. //M1卡的某一块写为如下格式,则该块为钱包,可接收扣款和充值命令
  13. //4字节金额(低字节在前)+4字节金额取反+4字节金额+1字节块地址+1字节块地址取反+1字节块地址+1字节块地址取反

  14. //uchar code money[4]      = {1,0,0,0};
  15. uchar code DefaultKey[6] = {0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF}; //初始密码
  16. uchar code administer_key[6]={0,0,0,0,0,0};//管理员卡密码
  17. uchar code this=0x01;
  18. uchar code bianhao[16]={0x01,0x00,0x01,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00};
  19. //*********全局变量定义*********************************//

  20. static uchar xdata Rec_Buffer[REC_BUFFER_SIZE];                //串口接收缓冲区
  21. static uchar Recvd_Count;                                                 //串口已接收数据的个数
  22. unsigned char g_ucTempbuf1[4];  //返回卡号       
  23. unsigned char g_ucTempbuf2[16]; //返回块中16位数据                     

  24. bit  time_flag=0;//1秒时间标志位
  25. bit  mode     =0;//模式选择标志位,0为定时计费模式,1为流量计费模式
  26. static uint gather_money=0;//汇总金额变量,需要充分考虑停电问题????????????????????



  27. /*****************************************************************************
  28. *原型:void time0_init(void)
  29. *功能:定时器0初始化
  30. *input:无
  31. *ouput:无
  32. 用于定时计费
  33. ******************************************************************************/
  34. void time0_init(void)
  35. {

  36.     if(mode==0)  
  37.     {
  38.           TMOD  = TMOD|0x01;
  39.           TH0   = 0x10;
  40.           TL0   = 0x00;//4096,定时15次就是1S,11.0592M
  41.         }
  42.         if(mode==1)
  43.         {
  44.             TMOD  = TMOD|0x05;//计外部脉冲
  45.           TH0   = 0xff;
  46.           TL0   = 0xfe;//一个脉冲来则溢出
  47.           TR0   =1;
  48.         }
  49. //          TR0   =1;
  50.           ET0   =1;   
  51. }
  52. void timer0() interrupt 1
  53. {

  54.   static uchar overflow=0;
  55.   if(mode==0)
  56.   {

  57.         TH0   = 0x10;
  58.         TL0   = 0x00;//4096,定时15次就是1S,11.0592M
  59.         overflow++;
  60.         if(overflow>=15)//注意:如果overflow未付初值,此处if(overflow==15),第一次得不到立即响应,改成>=则可以立即响应
  61.         {
  62.     overflow=0;
  63.         time_flag=1;
  64.         LED=~LED;//绿色指示灯闪烁,表示正在计费
  65.         }
  66.   }
  67.   if(mode==1)
  68.   {
  69.             TH0   = 0xff;
  70.           TL0   = 0xfe;//一个脉冲来则溢出
  71.           time_flag=1;
  72.   }
  73.   

  74. }



  75. //-------------------------------- ------------------------------------------------------------------
  76. // 函数名称: delay
  77. // 入口参数: N
  78. // 函数功能:延时子程序,实现(16*N+24)us的延时
  79. // 系统采用11.0592MHz的时钟时,延时满足要求,其它情况需要改动
  80. //--------------------------------------------------------------------------------------------------
  81. void Delay_ms(uint N)      
  82. {
  83.   uint i,j;
  84.   for(j=0;j<1000;j++)
  85.   for(i=0;i<=N;i++);

  86. }

  87. void Pass()
  88. {
  89.   beep=0;
  90.   Delay_ms(50);
  91.   beep=1;

  92. }
  93. /*******************************************************************************
  94. * Function Name  : UART_Init
  95. * Description    : 初始化串行口和波特率发生器(用定时器1)
  96. * Input          : None
  97. * Output         : None
  98. * Return         : None
  99. *******************************************************************************/
  100. void UART_Init(void)
  101. {

  102.         SCON =0x50;            //选择串口工作方式,打开接收允许
  103.         TMOD =TMOD|0x21;            //定时器1工作在方式2,定时器0工作在方式1
  104.         PCON|=0x80;
  105.     TH1=0xff;                             //BaudRate=57600(系统时钟11.0592MHZ)
  106.     TL1=0xff;
  107.         TR1  =1;               //启动定时器T1
  108.         ET1  =0;

  109.         TR0         =1;                            //启动定时器T0
  110.     ET0         =1;                           //允许定时器0中断
  111.         ES         =1;               //允许串行口中断
  112.        
  113. }
  114. /*******************************************************************************
  115. * Function Name  : Sent_Byte
  116. * Description    : 发送一个字节到主机
  117. * Input          : Sdata:要发送的字节
  118. * Output         : None
  119. * Return         : None
  120. *******************************************************************************/
  121. void Sent_Byte(unsigned char Sdata)
  122. {
  123.         TI=0;
  124.         SBUF=Sdata;
  125.         while(TI==0) ;
  126.         TI=0;
  127. }
  128. /*******************************************************************************
  129. * Function Name  : Sent_String
  130. * Description    : 发送字节串到主机
  131. * Input          : pt_send:要发送的字符串
  132. * Output         : None
  133. * Return         : None
  134. *******************************************************************************/
  135. void Sent_String(unsigned char *pt_send)
  136. {
  137. TI=0;
  138.   while(*pt_send!='\0')
  139.        {
  140.         Sent_Byte(*pt_send++);
  141.        }
  142. }
  143. /*******************************************************************************
  144. * Function Name  : Sent_Buffer
  145. * Description    : 向串口1发送指定长度的数据
  146. * Input          : string:发送缓冲区指针;len:发送长度.
  147. * Output         : None
  148. * Return         : None
  149. *******************************************************************************/
  150. void Sent_Buffer(uchar *string,uchar len)
  151. {uchar i;
  152.         ES        =        0;
  153.           for(i=0;i<len;i++)
  154.            {
  155.             Sent_Byte(*string++);
  156.        }
  157.         ES        =        1;
  158. }

  159. //********************主函数******************************************
  160. main()
  161. {
  162.    
  163.     uchar status;
  164.         unsigned long int display_data=0;
  165.         WDT_Disable;
  166.         UART_Init();                //初始化串口
  167.         EA   =1;                //单片机中断允许
  168.     //初始化射频芯片
  169.     PcdReset();
  170.     PcdAntennaOff();
  171.     PcdAntennaOn();  
  172.     Delay_ms(100);
  173.        time0_init();       //初始化定时器0,要在读mode以后

  174.           //复位芯片,打开天线
  175.           PcdReset();   
  176.           PcdAntennaOff();
  177.           PcdAntennaOn();  
  178.           Delay_ms(100);

  179.     while(1)
  180.          {  
  181.                     //寻卡,输出为卡类型
  182.          status = PcdRequest(PICC_REQALL, g_ucTempbuf1);//*PICC_REQALL=0x52:寻天线区内所有符合14443A标准的卡  PICC_REQIDL=0x26:只寻未进入休眠状态的卡                     
  183.          if (status == MI_OK)
  184.                  status = PcdAnticoll(g_ucTempbuf1);  //防冲撞处理,输出卡片序列号,4字节

  185.          if (status == MI_OK)
  186.                status = PcdSelect(g_ucTempbuf1);    //选择卡片,输入卡片序列号,4字节

  187.          if (status == MI_OK)
  188.                    status = PcdAuthState(PICC_AUTHENT1A, 1, DefaultKey, g_ucTempbuf1);

  189.           if (status == MI_OK)   
  190.                    status = PcdRead(1, g_ucTempbuf2);//读卡
  191.          
  192.          // if (status == MI_OK)
  193.                   //{       
  194.                       //status=PcdWrite(1,bianhao);
  195.                  // }

  196.                  if (status == MI_OK)
  197.                    status = PcdRead(1,g_ucTempbuf2);//读卡

  198.                   if(status==MI_OK)
  199.                   {
  200.                   Pass();
  201.                  //Sent_Byte(this);
  202.                  Sent_Byte(g_ucTempbuf1[0]);Sent_Byte(g_ucTempbuf1[1]);Sent_Byte(g_ucTempbuf1[2]);Sent_Byte(g_ucTempbuf1[3]); //卡号

  203.                  Sent_Byte(g_ucTempbuf2[0]);Sent_Byte(g_ucTempbuf2[1]);Sent_Byte(g_ucTempbuf2[2]);Sent_Byte(g_ucTempbuf2[3]); //卡中第一块数据内容
  204.                  Sent_Byte(g_ucTempbuf2[4]);Sent_Byte(g_ucTempbuf2[5]);Sent_Byte(g_ucTempbuf2[6]);Sent_Byte(g_ucTempbuf2[7]);
  205.                  Sent_Byte(g_ucTempbuf2[8]);Sent_Byte(g_ucTempbuf2[9]);Sent_Byte(g_ucTempbuf2[10]);Sent_Byte(g_ucTempbuf2[11]);
  206.                  Sent_Byte(g_ucTempbuf2[12]);Sent_Byte(g_ucTempbuf2[13]);Sent_Byte(g_ucTempbuf2[14]);Sent_Byte(g_ucTempbuf2[15]);

  207.                   }

  208.        

  209.   }
  210. }

  211. /*******************************************************************************
  212. * Function Name  : Serial ()
  213. * Description    : 串口中断函数
  214. * Input          : None
  215. * Output         : None
  216. * Return         : None
  217. *******************************************************************************/
  218. void   Serial ()     interrupt    4          using 2
  219. {
  220.         EA = 0;
  221.      if(RI)
  222.      { RI=0;
  223.            if(Recvd_Count>=REC_BUFFER_SIZE) Recvd_Count=REC_BUFFER_SIZE-1;
  224.             Rec_Buffer[Recvd_Count++]=SBUF;
  225.      }
  226.          EA = 1;
  227. }
复制代码

所有资料51hei提供下载:
RFID&amp;#143;.rar (77.9 KB, 下载次数: 10)


评分

参与人数 1黑币 +50 收起 理由
admin + 50 共享资料的黑币奖励!

查看全部评分

分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏 分享淘帖 顶 踩
回复

使用道具 举报

沙发
ID:1 发表于 2018-10-7 13:45 | 只看该作者
补全原理图或者详细说明一下电路连接即可获得100+黑币
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

手机版|小黑屋|51黑电子论坛 |51黑电子论坛6群 QQ 管理员QQ:125739409;技术交流QQ群281945664

Powered by 单片机教程网

快速回复 返回顶部 返回列表