MIFARE系列8《D8M1.exe》
软件名:D8M1.exe
更新时间:2014.06.28
操作系统:windowAll
外部设备:D8读卡器
D8M1可以对MIFARE块读写操作,支持1K,4K。检验KEY后返回SAK,QTAQ,UID。基于D8读卡器提供的dcrf32.dll开发。
D8型IC卡读写器是开发IC卡相关产品及系统集成必备的前端处理设备,可读写双界面射频智能卡或单独的非接触式射频卡,通过RS232串行接口或USB口实现同PC机及相关设备的连接,USB采用无驱技术,可方便用户的安装使用,它对多卡的支持可用于安全发卡及那些安全要求较高的领域需要。
核心代码如下:
void CD8M1Dlg::Show(CString str)
{
time = CTime::GetCurrentTime();
CString strTime = time.Format("%H:%M:%S");
int len = editShow.GetWindowTextLength();
editShow.SetSel(len, len);
editShow.ReplaceSel(strTime + " ----> " + str + _T("\r\n"));
} void CD8M1Dlg::Beer()
{
UCHAR SONG_TONE[] = { 212, 212, 190, 212, 159, 169, 212, 212, 190, 212, 142, 159, 212, 212, 106, 126, 159, 169, 190, 119, 119, 126, 159, 142, 159, 0 }; //生日快乐歌的音符频率表,不同频率由不同的延时来决定
UCHAR SONG_LONG[] = { 9, 3, 12, 12, 12, 24, 9, 3, 12, 12, 12, 24, 9, 3, 12, 12, 12, 12, 12, 9, 3, 12, 12, 12, 24, 0 }; //生日快乐歌节拍表,节拍决定每个音符的演奏长短 int len = 6;
for (int i = 0; i < len; i++){
dc_beep(icdev, SONG_LONG[i]/3);
Sleep(SONG_TONE[i]);
}
} void CD8M1Dlg::OnBnClickedInitcom()
{
//初始化串口1,
icdev = dc_init(100, 9600);
if ((int)icdev <= 0){
Show("Init Com Error!");
}
else{
Show("Init Com OK!");
}
dc_beep(icdev, 1);//蜂鸣时间,单位是10毫秒
Sleep(30);
dc_beep(icdev, 1);
Sleep(60);
dc_beep(icdev, 1);
// Beer(); } void CD8M1Dlg::OnBnClickedLoadKey()
{
//下载密码
CString keys;
GetDlgItemText(IDC_EDIT_KEY, keys);
int pos = keys.Find("\r\n");
UCHAR uKey[6];
while (pos != -1){
CString key = keys.Left(pos).Trim();
keys = keys.Mid(pos+2);
unsigned char _SecNr = StrToIntA(key.Left(2));
CString keyN = key.Mid(3);
if (_SecNr > 40){
Show("扇区号有误,大于40扇区...");
}
memset(uKey, 0, 6);
Alg::HexToAsc(keyN, uKey);
int st = dc_load_key(icdev, GetKeyMode(), _SecNr, uKey);
if (st != 0){
Show(IntToStr(_SecNr) + ": 扇区密钥写入失败...");
return;
} pos = keys.Find("\r\n");
} Show("载入KEY成功...\r\n");
} void CD8M1Dlg::OnBnClickedVerifyCard()
{
//寻卡函数,
// int st = dc_card(icdev, 0, &cardsnr);
CString linstr;
unsigned short tagType;
int st = dc_request(icdev, 0, &tagType);
if (st != 0)
{
Show("Find Card Error!");
return;
}
else
{
Show("Find Card Ok!");
linstr.Format("%04d", tagType);
Show("ATQA:" + linstr);
} st = dc_anticoll(icdev, 0, &cardsnr);
if (st != 0)
{
Show("Find Card Error!");
return;
}
else
{
linstr.Format("%X", cardsnr);
Show("UID:" + linstr);
} UCHAR size;
st = dc_select(icdev, cardsnr, &size);
if (st != 0)
{
Show("select Card Error!");
return;
}
else
{
linstr.Format("%X", size);
Show("SAK:" + linstr);
} //核对密码
int sec = GetSecNr();
int keyMode = GetKeyMode();
for (int i = 0; i < sec; i++){
st = dc_authentication(icdev, keyMode, i);
if (st != 0){
Show(IntToStr(i) + ": Auth Card Error...");
return;
}
}
Show("核对密码完成...\r\n");
} void CD8M1Dlg::OnBnClickedRead()
{
EditBlock.SetWindowTextA("");
ClearShow(); int adrs = GetBlockNr();
CString sData;
UCHAR pData[32]; unsigned long _NSnr;
for (int i = 0; i < adrs; i++){
//int st = dc_read(icdev, i, data); if (IsCheckW()){//only read block 3
if ((i < 128) && ((i+1) % 4 != 0)){
continue;
} if ((i > 128) && ((i+1) % 16 != 0)){
continue;
}
}
memset(pData, 0, 32);
int st = dc_HL_read(icdev, 0, i, cardsnr, pData, &_NSnr);
Alg::AscToHex(pData, 16, sData); if (st != 0){
Show(IntToStr(i) + ": 读取失败...");
continue;
}
else{
Show(IntToStr(i) + ": 读取成功," + sData);
} int len = EditBlock.GetWindowTextLength();
EditBlock.SetSel(len, len);
EditBlock.ReplaceSel(IntToStr(i) + ":" + sData + _T("\r\n"));
} Show("读取块完成...\r\n");
} void CD8M1Dlg::OnBnClickedWrite()
{
ClearShow();
CString blocks;
int adrs = GetBlockNr();
GetDlgItemText(IDC_EDIT_BLOCK, blocks);
int pos = blocks.Find("\r\n");
UCHAR uData[16];
while (pos != -1){
CString block = blocks.Left(pos).Trim();
blocks = blocks.Mid(pos + 2);
int posn = block.Find(':');
if (posn == -1){
Show("块地址值有误," + block);
return;
}
unsigned char adr = StrToIntA(block.Left(posn));
CString data = block.Mid(posn + 1);
if (data.GetLength() != 32){
Show("块值长度有误," + block);
}
if (adr > adrs){
Show("块地址越界:" + IntToStr(adr));
return;
} Alg::HexToAsc(data, uData); int st = dc_HL_write(icdev, 0, adr, &cardsnr, uData);
if (st != 0){
Show(IntToStr(adr) + ": 写入失败...");
}
else{
Show(IntToStr(adr) + ": 写入成功,写入值 " + data);
}
pos = blocks.Find("\r\n");
} Show("写入块完成...\r\n");
} void CD8M1Dlg::OnClose()
{
dc_exit(icdev);
CDialogEx::OnClose();
}
软件下载地址:http://download.csdn.net/detail/yxstars/7675429
文/闫鑫原创转载请注明出处http://blog.csdn.net/yxstars/article/details/38108709
MIFARE系列8《D8M1.exe》的更多相关文章
- Mifare系列6-射频卡与读写器的通信(转)
文/闫鑫原创转载请注明出处http://blog.csdn.net/yxstars/article/details/38085415 1. 复位应答(Answer to request) 读写器呼叫磁 ...
- Mifare系列1-简介(转)
文章转自 文/闫鑫原创转载请注明出处http://blog.csdn.net/yxstars/article/details/38079827 感谢原创作者的辛勤,对您再次表达感谢! 随着社会的发展, ...
- MIFARE系列6《射频卡与读写器的通讯》
1. 复位应答(Answer to request) 读写器呼叫磁场内的卡片,卡片对呼叫做出应答.对刚进入磁场得到电复位处于休闲状态的卡片,卡请求(REQA,0x26):对于已进行过读写操作并进入休眠 ...
- MIFARE系列1《MIFARE简介》
随着社会的发展,智能卡在很多领域得到了广泛的应用.特别是非接触卡,由于使用方便以及功能强大的特点,在管理.公交.工作证.身份识别等领域得到了快速的普及和推广. 非接触卡已经逐步发展成为一个独立的跨学科 ...
- 射频识别技术漫谈(11)——Mifare系列卡的共性【worldsing笔记】
Mifare是NXP公司生产的一系列遵守ISO14443A标准的射频卡,包Mifare S50.Mifare S70.Mifare UltraLight.Mifare Pro.Mifare Desfi ...
- 射频识别技术漫谈(11)——Mifare系列卡的共性
Mifare是NXP公司生产的一系列遵守ISO14443A标准的射频卡,包Mifare S50.Mifare S70.Mifare UltraLight.Mifare Pro.Mifare Desfi ...
- MIFARE系列6《射频卡与读写器的通信》
1. ATR(Answer to request) 读写器呼叫磁场内的卡片.卡片对呼叫做出应答. 对刚进入磁场得到电复位处于休闲状态的卡片,卡请求(REQA,0x26):对于已进行过读写操作并进入休眠 ...
- C#程序集系列06,程序集清单,EXE和DLL的区别
CLR在加载程序集的时候会查看程序集清单,程序集清单包含哪些内容呢?可执行文件和程序集有什么区别/ 程序集清单 □ 查看程序集清单 →清空F盘as文件夹中的所有内容→创建MainClass.cs文件→ ...
- Mifare系列7-安全性(转)
文/闫鑫原创转载请注明出处http://blog.csdn.net/yxstars/article/details/38087245 飞利浦的MIFARE卡 由于它的高安全性在市场上得到广泛应用,比如 ...
随机推荐
- [UI]Flat UI - Free Boorstrap Framework and Theme
---------------------------------------------------------------------------------------------------- ...
- Github 恶搞教程(一起『玩坏』自己的 Github 吧)
最近在伯乐在线读到一篇趣文,<如何在 Github『正确』做贡献>,里面各种能人恶搞 Github 的『Public contributions』,下面截取几个小伙伴的战绩: 顺藤摸瓜,发 ...
- Flex4 DataGrid实现可复制单元格,同时解决自定义GridItemRenderer出现1009错误的方法
原创内容,如需转载,请注明出处,谢谢 最近在项目中发现Flex的DataGrid不支持内容复制,在涉及到保护敏感数据时倒是很有用处,但大部分情况下,我们还是希望客户能够直接复制DataGrid单元格中 ...
- update field
UPDATE dbo.HotelPolicy SET HPFactorMark=TB.MarkValue FROM (select HPF.HPFRPolicyId AS ID ,CONVERT(i ...
- Java中几种常见的排序方式
冒泡排序是一种简单的排序算法.它重复地走访过要排序的数列,一次比较两个元素,如果他们的顺序错误就把他们交换过来.走访数列的工作是重复地进行直到没有再需要交换,也就是说该数列已经排序完成.这个算法的名字 ...
- JS 点击按钮后弹出遮罩层,有关闭按钮
<!DOCTYPE html> <html xmlns="http://www.w3.org/1999/xhtml"> <head> <t ...
- 两个正在运行的activity之间的通信
在android应用程序开发的时候,从一个activity启动另一个activity并传递一些数据到新的activity非常的简单,但是当您需要让后台运行的activity回到前台并传递一些数据可能就 ...
- 避免使用CreateThread函数,导致的内存泄露
原文链接:http://blog.csdn.net/solosure/article/details/6262877
- php实现树状结构无级分类
php实现树状结构无级分类 ).",'树2-1-1-2')";mysql_query($sql);?>
- Eclipse 安装Groovy插件
摘自: http://blog.csdn.net/boonya/article/details/45399901 步骤一: 下载eclipse4.3.0,地址:http://www.eclipse.o ...