USB-ID读卡器开发文档

2023-11-27 22:30
文章标签 文档 开发 id usb 读卡器

本文主要是介绍USB-ID读卡器开发文档,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

QQ:954486673

微信:13822155058

淘宝:https://item.taobao.com/item.htm?spm=a1z10.1-c.w4004-17663462243.14.60cc6baabEEfYn&id=562957272162

OUR_IDR.dll动态库使用说明

  • 动态库简介

动态库OUR_IDR.dll用VC6.0++开发,编译成Release实体,适用于WIN98、NT、2000、XP、2003环境。本文档下面的源代码例子是C++builder 的调用格式。

本动态库是本公司免驱型USB接口ID卡读卡器的配套文件,必须和免驱型读卡器一起使用。免驱型读卡器使用的是HID人体学输入设备USB模式,即插即用,可在Win2000、XP、2003、Win7下使用,更可以在嵌入式系统WinCE下使用,但在WinCE下不是用OUR_IDR.dll动态库,本公司另外提供,如有需要请查看其他文档。

推荐用动态调用的方法使用本动态库。

一、让读卡器发出声音

函数名:idr_beep

功能

让读卡器发出声响。(暂不开放对指示灯的控制,如果有特殊要求请致电本公司)      

原始声明

unsigned char __stdcall idr_beep (unsigned long xms)

输入

xms为响声的时间长度,单位为2毫秒

返回

返回unsigned char值。

0

操作成功,。

22

动态库或驱动程序异常,解决方法是退出程序,拔出ID卡读卡器,重装驱动程序再插上ID卡读卡器重试,或者重新拷贝动态库OUR_IDR.dll到正确的位置。

24

操作超时。可能是电脑中毒导致USB帧传递调度缓慢,或者是ID卡读卡器有问题,解决方法是重启电脑或重新拔插ID卡读卡器。

27

USB传输不稳定导致传输的字符不全。不需理会这个错误,因为基本上是不会出现这个错误的。

28

USB传输不稳定导致CRC校验错。不需理会这个错误,因为基本上是不会出现这个错误的。

其他

未知错误

例子及注释

请要本公司网站下载各种开发工具的例子源代码,本函数的声明和输入参数格式可以直接套用,谢谢使用

二、读卡并返回卡的全部五个字节信息(ID卡厂商信息和卡序列号)

函数名:idr_read

功能

寻卡并返回该卡的序列号,如果卡在感应区,每次执行均返回卡号

原始声明

unsigned char __stdcall idr_read (unsigned char *serial)

输入

形参*serial只需指向一个至少已分配了5个char空间的可写数组 unsigned char *指针, serial的下标由0开始。Serial数组的内容无需赋值,因为此数组仅用于返回值。

返回

返回unsigned char值,并将寻到的卡的序列号传值到*serial数组。

0

操作成功,*serial数组中的数据有效。

8

寻卡错误,根本就没有卡在感应区,*serial无效。

22

动态库或驱动程序异常,解决方法是退出程序,拔出ID卡读卡器,重装驱动程序再插上ID卡读卡器重试,或者重新拷贝动态库OUR_IDR.dll到正确的位置。

24

操作超时。可能是电脑中毒导致USB帧传递调度缓慢,或者是ID卡读卡器有问题,解决方法是重启电脑或重新拔插ID卡读卡器。

28

USB传输不稳定导致CRC校验错。不需理会这个错误,因为基本上是不会出现这个错误的。

其他

未知错误

例子及注释

/*******************{{piccrequest函数使用特例*********************************/

        //卡序列号缓冲

        unsigned char myserial[5];

        unsigned char status;

        //函数指针声明

        unsigned char (__stdcall *idr_read)(unsigned char *serial);

        //提示当前目录

        AnsiString FileName=ExtractFilePath(Application->ExeName);

         //如果中没有"\"字符,就加进去

        if(FileName.SubString(FileName.Length(),1) != "\\")

        {

             FileName += "\\";

        }

        FileName += "OUR_IDR.dll";

        if(!FileExists(FileName))

        {//如果文件不存在

                ShowMessage("无法在应用程序的文件夹找到ID卡读卡器动态库");

                return; //返回

        }

        HINSTANCE hDll;

        //加载动态库

        hDll=LoadLibrary(FileName.c_str());

        //提取动态库

        idr_read = (unsigned char (__stdcall * idr_read)(unsigned char *serial))GetProcAddress(hDll," idr_read ");

        //调用函数

        status = idr_read (myserial);

        //返回值处理

        switch(status)

        {

                case 0:

                        //TO-DO相应的处理,请在以下加入代码

                        break;

                case 1:

                        break;

                //...

         }

函数名:idr_read_8h10d_str

功能

寻卡并返回该卡的序列号,以字符串方式返回十位十进制卡号

原始声明

LPCSTR __stdcall idr_read_8h10d_str(void)

输入

返回

返回LPCSTR值,。

10位卡号

操作成功返回十位卡号字符串

ER08

寻卡错误,根本就没有卡在感应区,*serial无效。

ER22

动态库或驱动程序异常,解决方法是退出程序,拔出ID卡读卡器,重装驱动程序再插上ID卡读卡器重试,或者重新拷贝动态库OUR_IDR.dll到正确的位置。

ER24

操作超时。可能是电脑中毒导致USB帧传递调度缓慢,或者是ID卡读卡器有问题,解决方法是重启电脑或重新拔插ID卡读卡器。

ER28

USB传输不稳定导致CRC校验错。不需理会这个错误,因为基本上是不会出现这个错误的。

其他

未知错误

例子及注释

Dim retstr As String '存放返回值

retstr = idr_read_8h10d_str()

retstr = Left(retstr, 10)

retstr = Trim(retstr)

If Len(retstr) < 10 Then

'有错误

    Select Case retstr

    Case "ER08":

   

        MsgBox "请将卡放在感应区"

       

    Case "ER23":

   

        MsgBox "机器没连上,或驱动程序未安装!"

       

   

    Case Else

        MsgBox "异常"

    End Select

ElseIf Len(retstr) = 10 Then

   

        MsgBox ("读卡成功,卡号为" + retstr)

End If

三、读卡并返回卡的全部五个字节信息(ID卡厂商信息和卡序列号)

函数名:idr_read_once

功能

寻卡并返回该卡的序列号,如果卡在感应区,第一次执行返回卡号,再次执行提示寻不到卡,必须拿开卡隔一时间段再放到感应区,才能读卡成功。这种功能是用于刷卡一次卡仅返回一次卡号的情况。

原始声明

unsigned char __stdcall idr_read_ once (unsigned char *serial)

输入

形参*serial只需指向一个至少已分配了5个char空间的可写数组 unsigned char *指针, serial的下标由0开始。Serial数组的内容无需赋值,因为此数组仅用于返回值。

返回

返回unsigned char值,并将寻到的卡的序列号传值到*serial数组。

0

操作成功,*serial数组中的数据有效。

8

寻卡错误,根本就没有卡在感应区,*serial无效。

22

动态库或驱动程序异常,解决方法是退出程序,拔出ID卡读卡器,重装驱动程序再插上ID卡读卡器重试,或者重新拷贝动态库OUR_IDR.dll到正确的位置。

24

操作超时。可能是电脑中毒导致USB帧传递调度缓慢,或者是ID卡读卡器有问题,解决方法是重启电脑或重新拔插ID卡读卡器。

28

USB传输不稳定导致CRC校验错。不需理会这个错误,因为基本上是不会出现这个错误的。

其他

未知错误

例子及注释

/*******************{{piccrequest函数使用特例*********************************/

        //卡序列号缓冲

        unsigned char myserial[5];

        unsigned char status;

        //函数指针声明

        unsigned char (__stdcall *idr_read_ once)(unsigned char *serial);

        //提示当前目录

        AnsiString FileName=ExtractFilePath(Application->ExeName);

         //如果中没有"\"字符,就加进去

        if(FileName.SubString(FileName.Length(),1) != "\\")

        {

             FileName += "\\";

        }

        FileName += "OUR_IDR.dll";

        if(!FileExists(FileName))

        {//如果文件不存在

                ShowMessage("无法在应用程序的文件夹找到ID卡读卡器动态库");

                return; //返回

        }

        HINSTANCE hDll;

        //加载动态库

        hDll=LoadLibrary(FileName.c_str());

        //提取动态库

        idr_read = (unsigned char (__stdcall * idr_read)(unsigned char *serial))GetProcAddress(hDll," idr_read_ once ");

        //调用函数

        status = idr_read_ once (myserial);

        //返回值处理

        switch(status)

        {

                case 0:

                        //TO-DO相应的处理,请在以下加入代码

                        break;

                case 1:

                        break;

                //...

         }

函数名:idr_read_once_8h10d_str

功能

寻卡并返回该卡的序列号,以字符串方式返回十位十进制卡号

原始声明

LPCSTR __stdcall idr_read_ once_8h10d_str(void)

输入

返回

返回LPCSTR值,。

10位卡号

操作成功返回十位卡号字符串

ER08

寻卡错误,根本就没有卡在感应区,*serial无效。

ER22

动态库或驱动程序异常,解决方法是退出程序,拔出ID卡读卡器,重装驱动程序再插上ID卡读卡器重试,或者重新拷贝动态库OUR_IDR.dll到正确的位置。

ER24

操作超时。可能是电脑中毒导致USB帧传递调度缓慢,或者是ID卡读卡器有问题,解决方法是重启电脑或重新拔插ID卡读卡器。

ER28

USB传输不稳定导致CRC校验错。不需理会这个错误,因为基本上是不会出现这个错误的。

其他

未知错误

例子及注释

Dim retstr As String '存放返回值

retstr = idr_read_ once_8h10d_str()

retstr = Left(retstr, 10)

retstr = Trim(retstr)

If Len(retstr) < 10 Then

'有错误

    Select Case retstr

    Case "ER08":

   

        MsgBox "请将卡放在感应区"

       

    Case "ER23":

   

        MsgBox "机器没连上,或驱动程序未安装!"

       

   

    Case Else

        MsgBox "异常"

    End Select

ElseIf Len(retstr) = 10 Then

   

        MsgBox ("读卡成功,卡号为" + retstr)

End If

四、读出读卡器各自编码唯一的设备号

函数名:pcdgetdevicenumber

功能

读出读卡器各自编码唯一的设备号,此设备号可用于软件的产权保护,功能跟软件加密码类似。

原始声明

unsigned char __stdcall pcdgetdevicenumber(unsigned char *devicenumber);

输入

形参* devicenumber只需指向一个至少已分配了4个char空间的可写数组 unsigned char *指针,devicenumber的下标由0开始。devicenumber数组的内容无需赋值,因为此数组仅用于返回值。

返回

返回unsigned char值,并将寻到的卡的序列号传值到* devicenumber数组。

0

操作成功,* devicenumber数组中的数据有效。

22

动态库或驱动程序异常,解决方法是退出程序,拔出ID卡读卡器,重装驱动程序再插上ID卡读卡器重试,或者重新拷贝动态库OUR_IDR.dll到正确的位置。

24

操作超时。可能是电脑中毒导致USB帧传递调度缓慢,或者是ID卡读卡器有问题,解决方法是重启电脑或重新拔插ID卡读卡器。

28

USB传输不稳定导致CRC校验错。不需理会这个错误,因为基本上是不会出现这个错误的。

其他

未知错误

例子及注释

/*******************{{piccrequest函数使用特例*********************************/

        //卡序列号缓冲

        unsigned char devicenumber [5];

        unsigned char status;

        //函数指针声明

        unsigned char (__stdcall * pcdgetdevicenumber)(unsigned char * devicenumber);

        //提示当前目录

        AnsiString FileName=ExtractFilePath(Application->ExeName);

         //如果中没有"\"字符,就加进去

        if(FileName.SubString(FileName.Length(),1) != "\\")

        {

             FileName += "\\";

        }

        FileName += "OUR_IDR.dll";

        if(!FileExists(FileName))

        {//如果文件不存在

                ShowMessage("无法在应用程序的文件夹找到ID卡读卡器动态库");

                return; //返回

        }

        HINSTANCE hDll;

        //加载动态库

        hDll=LoadLibrary(FileName.c_str());

        //提取动态库

        idr_read = (unsigned char (__stdcall * pcdgetdevicenumber)(unsigned char * devicenumber))GetProcAddress(hDll," pcdgetdevicenumber ");

        //调用函数

        status = pcdgetdevicenumber (devicenumber);

        //返回值处理

        switch(status)

        {

                case 0:

                        //TO-DO相应的处理,请在以下加入代码

                        break;

                case 1:

                        break;

                //...

         }

函数名:pcdgetdevicenumber_str

功能

读出读卡器各自编码唯一的设备号,此设备号可用于软件的产权保护,功能跟软件加密码类似。

原始声明

LPCSTR __stdcall pcdgetdevicenumber_str(void)

返回

返回 LPCSTR 字符串

10位设备号

操作成功,返回10位设备号。

ER22

动态库或驱动程序异常,解决方法是退出程序,拔出ID卡读卡器,重装驱动程序再插上ID卡读卡器重试,或者重新拷贝动态库OUR_IDR.dll到正确的位置。

ER 24

操作超时。可能是电脑中毒导致USB帧传递调度缓慢,或者是ID卡读卡器有问题,解决方法是重启电脑或重新拔插ID卡读卡器。

ER 28

USB传输不稳定导致CRC校验错。不需理会这个错误,因为基本上是不会出现这个错误的。

其他

未知错误

例子及注释

Dim retstr As String '存放返回值

retstr = pcdgetdevicenumber_str()

retstr = Left(retstr, 10)

retstr = Trim(retstr)

If Len(retstr) < 10 Then

'有错误

    Select Case retstr

       

    Case "ER23":

   

        MsgBox "机器没连上,或驱动程序未安装!"

        

   

    Case Else

        MsgBox "异常"

    End Select

ElseIf Len(retstr) = 10 Then

   

        MsgBox ("设备号十进制为" + retstr)

End If

注:原始声明指动态库的VC源码内的声明。

这篇关于USB-ID读卡器开发文档的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/428564

相关文章

SpringBoot整合mybatisPlus实现批量插入并获取ID详解

《SpringBoot整合mybatisPlus实现批量插入并获取ID详解》这篇文章主要为大家详细介绍了SpringBoot如何整合mybatisPlus实现批量插入并获取ID,文中的示例代码讲解详细... 目录【1】saveBATch(一万条数据总耗时:2478ms)【2】集合方式foreach(一万条数

Go语言开发实现查询IP信息的MCP服务器

《Go语言开发实现查询IP信息的MCP服务器》随着MCP的快速普及和广泛应用,MCP服务器也层出不穷,本文将详细介绍如何在Go语言中使用go-mcp库来开发一个查询IP信息的MCP... 目录前言mcp-ip-geo 服务器目录结构说明查询 IP 信息功能实现工具实现工具管理查询单个 IP 信息工具的实现服

使用Python从PPT文档中提取图片和图片信息(如坐标、宽度和高度等)

《使用Python从PPT文档中提取图片和图片信息(如坐标、宽度和高度等)》PPT是一种高效的信息展示工具,广泛应用于教育、商务和设计等多个领域,PPT文档中常常包含丰富的图片内容,这些图片不仅提升了... 目录一、引言二、环境与工具三、python 提取PPT背景图片3.1 提取幻灯片背景图片3.2 提取

usb接口驱动异常问题常用解决方案

《usb接口驱动异常问题常用解决方案》当遇到USB接口驱动异常时,可以通过多种方法来解决,其中主要就包括重装USB控制器、禁用USB选择性暂停设置、更新或安装新的主板驱动等... usb接口驱动异常怎么办,USB接口驱动异常是常见问题,通常由驱动损坏、系统更新冲突、硬件故障或电源管理设置导致。以下是常用解决

Android实现在线预览office文档的示例详解

《Android实现在线预览office文档的示例详解》在移动端展示在线Office文档(如Word、Excel、PPT)是一项常见需求,这篇文章为大家重点介绍了两种方案的实现方法,希望对大家有一定的... 目录一、项目概述二、相关技术知识三、实现思路3.1 方案一:WebView + Office Onl

Python实现word文档内容智能提取以及合成

《Python实现word文档内容智能提取以及合成》这篇文章主要为大家详细介绍了如何使用Python实现从10个左右的docx文档中抽取内容,再调整语言风格后生成新的文档,感兴趣的小伙伴可以了解一下... 目录核心思路技术路径实现步骤阶段一:准备工作阶段二:内容提取 (python 脚本)阶段三:语言风格调

使用Java将DOCX文档解析为Markdown文档的代码实现

《使用Java将DOCX文档解析为Markdown文档的代码实现》在现代文档处理中,Markdown(MD)因其简洁的语法和良好的可读性,逐渐成为开发者、技术写作者和内容创作者的首选格式,然而,许多文... 目录引言1. 工具和库介绍2. 安装依赖库3. 使用Apache POI解析DOCX文档4. 将解析

使用Python开发一个带EPUB转换功能的Markdown编辑器

《使用Python开发一个带EPUB转换功能的Markdown编辑器》Markdown因其简单易用和强大的格式支持,成为了写作者、开发者及内容创作者的首选格式,本文将通过Python开发一个Markd... 目录应用概览代码结构与核心组件1. 初始化与布局 (__init__)2. 工具栏 (setup_t

Spring Shell 命令行实现交互式Shell应用开发

《SpringShell命令行实现交互式Shell应用开发》本文主要介绍了SpringShell命令行实现交互式Shell应用开发,能够帮助开发者快速构建功能丰富的命令行应用程序,具有一定的参考价... 目录引言一、Spring Shell概述二、创建命令类三、命令参数处理四、命令分组与帮助系统五、自定义S

Python通过模块化开发优化代码的技巧分享

《Python通过模块化开发优化代码的技巧分享》模块化开发就是把代码拆成一个个“零件”,该封装封装,该拆分拆分,下面小编就来和大家简单聊聊python如何用模块化开发进行代码优化吧... 目录什么是模块化开发如何拆分代码改进版:拆分成模块让模块更强大:使用 __init__.py你一定会遇到的问题模www.