前段时间有个项目在客户端web下使用IC卡读卡器,试了很多种方案都觉得麻烦,最后在网上找了个现成的方案,采用了YW-605HA读卡器,厂家就不说了,免得说做广告。开发起来也挺简单。

他们将IC卡读卡器接口封装成ocx文件,分为32位版本和64位版本,自动安装时自动判断32位还是64位,这个比较方便,要不然按照版本部署客户端,那可得累死了。他们的说明如下:

控件文件名称:yw60x.ocx

32位控件:x86\yw60x.ocx

64位控件:x64\yw60x.ocx

用户可以根据B/S客户端的环境配置相应的ocx文件,也可以采用安装包yw60xocxSetup.exe自动判断客户端的环境并且自动选择适合的ocx进行安装并注册

web读卡器ocx有静态调用和动态调用两种方法,这个做web开发的估计都熟悉,直接copy代码就行了,说明如下:

读写器控件yw60x.ocx类名:YW60X.yw60xCtrl.1

读写器控件yw60x.ocx的classid:167E1838-7388-4A24-86DE-985B91F0FFBF

在web中可以采用静态调用和动态调用的方法来初始化控件

动态调用方法:

var obj = new ActiveXObject("YW60X.yw60xCtrl.1");

静态调用方法:

<object id="yoworfidreader"

classid="clsid:167E1838-7388-4A24-86DE-985B91F0FFBF">

</object>

下面说说在web下我们如何与web读卡器进行交互,为了输出相应的参数,他们设计了几个输出性质的属性,如下:

属性名称

类型

含义

备注

LastResult

Long

最后一个函数执行后的返回值,与函数本身的返回值相同

判断函数的返回值与判断LastResult值是一样的

OutData1

Variant

一个Byte数组,函数执行要输出的首要内容

Byte数组可以在js和vbs里面自由转换成数组使用,或者使用控件自带的转换函数进行转换

OutData1Size

Long

OutData1数组的长度,字节数

OutData2

Variant

一个Byte数组,函数执行要输出的首要内容

OutData2Size

Long

OutData2数组的长度,字节数

OutData3

Variant

一个Byte数组,函数执行要输出的首要内容

OutData3Size

Long

OutData3数组的长度,字节数

所有的数据类型都是varaint类型的,与javascript非常兼容,但是在web中处理16进制数组是个麻烦的事,为此他们还设计了很多的类型转换函数,如下:

从数组获取所需格式的卡号字符串

函数原形:BSTR ConvertCardNo(VARIANT vCardNo, LONG ConvertIndex)

将数组转换成16进制的字符串

函数原形:BSTR GetHexStr(VARIANT vData);

将数组转换成ascii可见字符的字符串

函数原形:BSTR GetAlphaStr(VARIANT vData);

将16进制字符串转换成VARIANT类的数组

函数原形:VARIANT GetVariantFromHexStr(BSTR sHexStr);
  将普通符串转换成VARIANT类的数组

函数原形:VARIANT GetVariantFromAlphaStr(BSTR sAlphaStr);

看到这了,大家应该知道了。各种数据转换都是很方便的,下面看看怎么读卡,直接给一段代码吧,也是很简单的

function ReadCard()
 {
 var BlockID;
 var Key;
 RequestCard();
 BlockID = document.getElementById("BlockIDRead").value;
  
 Key =document.ReaderTest.GetVariantFromHexStr(document.getElementById("KeyRead").value);
 i = document.ReaderTest.YW_KeyAuthorization(1,96,BlockID,Key);
 if(i<0)
 {
 document.getElementById("DataRead").value ="密钥认证错误";
 return;
 }
  
 i = document.ReaderTest.YW_ReadaBlock(1,BlockID,16);
 if(i<0)
 {
 document.getElementById("DataRead").value ="读块错误";
 return;
 }
 document.getElementById("DataRead").value = document.ReaderTest.GetHexStr(document.ReaderTest.OutData1);
 document.ReaderTest.YW_Buzzer(1,5,5,1);
 CloseReader();
 }
  

很简单的吧

IC卡读卡器的web开发也可以采用友我科技RFID读写器云服务技术,将适应更多的web浏览器,如IE,Chrome,Firefox,safari,Opera等等

05-11 13:20