由于项目需要进行读卡操作,需要使用java进行读取dll文件
设备:德卡T10
1. 引入POM文件
<dependency>
<groupId>net.java.dev.jna</groupId>
<artifactId>jna</artifactId>
<version>5.6.0</version>
</dependency>

2.写入接口

import com.sun.jna.Library;import com.sun.jna.Native;
import com.sun.jna.NativeLong; public interface WINAPI extends Library{ WINAPI INSTANCE = Native.loadLibrary("SSCard",WINAPI.class);
//初始化
NativeLong Init(String s1, String s2);
//读取社保卡
NativeLong ReadCardBas(byte[] s1,int s2,byte[] s3,int s4);
//校验PIN码
NativeLong VerifyPIN(byte[] s1,int s2);
//修改PIN码
NativeLong ChangePIN(byte[] s1,int s2);
//读身份证信息
NativeLong ReadSFZ(byte[] s1,int s2,byte[] s3,int s4);
//读取二维码信息
NativeLong GetQRBase(int s0,byte[] s1,int s2,byte[] s3,int s4);
//校验医保密码
NativeLong VerifyYBPZPass(byte[] s1,int s2);
//修改医保密码
NativeLong ChangeYBPZPass(byte[] s1,byte[] s2,byte[] s3,byte[] s4,byte[] s5);
}

3.写对应的方法类
PS:
1.byte[]不是传入参数,而是返回参数,进行字节转字符串后才能获取对应的参数
2.由于德卡为了匹配大多数电脑,必须使用32位JDK才能读取成功,否则报错找不到dll文件路径
3.解码类型为GBK

德卡T10文档参照附件

import com.sun.jna.NativeLong;
import io.renren.modules.back.service.WINAPI;
import org.springframework.stereotype.Component;
import java.io.UnsupportedEncodingException; @Component
public class DKUtil {
public static String pUrl="http://10.126.105.66/hsa-hgs-adapt/api/card/initDll"; private static String test() throws UnsupportedEncodingException {
//jna linux相对路径调用c/c++接口时候,名称必须是lib开头,且第一个参数是lib后面的名称,如libtest.so,加载时候应该使用test来加载
//jna win相对路径调用c/c++接口时候,直接名称不加后缀调用,如test.dll,加载时候应该使用test来加载
//jna linux绝对路径调用c/c++接口时候,完整路径加上后缀,如test.so,加载时候应该使用/opt/test.so来加载
//jna win相对路径调用c/c++接口时候,完整路径可以不接后缀,如test.dll,加载时候应该使用D:\\test来加载
// Test lib = (Test) Native.loadLibrary("test_64", Test.class);
//Test lib = Native.loadLibrary(path, Test.class);
// 例1 NativeLong nativeLong = WINAPI.INSTANCE.Init(pUrl, "620100");
System.out.println("11111" + nativeLong);
byte[] chars1 = new byte[4096];
byte[] chars2 = new byte[4096];
NativeLong nativeLong1 = WINAPI.INSTANCE.ReadSFZ(chars1, 4096, chars2, 4096);
String result;
System.out.println("22222222:" + nativeLong1);
result = new String(chars1, "GBK");
result = result + "|" + new String(chars2, "GBK");
System.out.println(result);
return result;
} /**
* 初始化
* @returnR
*/
public static R init() {
NativeLong nativeLong= WINAPI.INSTANCE.Init(pUrl,"620100");
if (!"1".equals(nativeLong)){
return R.ok().put("msg","初始化成功");
}else {
return R.error().put("msg","初始化失败");
}
} /**
* 读取身份证信息
* @return
*/
public static R getSFZ() throws UnsupportedEncodingException {
R r=init();
if (!"0".equals(r.get("code").toString())){
return r;
}
byte[] chars1 = new byte[4096];
byte[] chars2 = new byte[4096];
NativeLong nativeLong=WINAPI.INSTANCE.ReadSFZ(chars1,4096,chars2,4096);
String result;
if ("0".equals(nativeLong.toString())){
result=new String(chars1,"GBK");
result=result+"|"+new String(chars2,"GBK");
System.out.println(result);
return R.ok().put("msg",result);
}else {
result=new String(chars1,"GBK");
result=result+"|"+new String(chars2,"GBK");
System.out.println(result);
return R.error().put("msg",result);
}
} /**
* 读取社保卡信息
* @return
*/
public static R getYBCard() throws UnsupportedEncodingException {
init(); byte[] chars1 = new byte[4096];
byte[] chars2 = new byte[4096];
NativeLong nativeLong=WINAPI.INSTANCE.ReadCardBas(chars1,4096,chars2,4096);
String result;
if ("1".equals(nativeLong)){
result=new String(chars1,"GBK");
result=result+"|"+new String(chars2,"GBK");
return R.ok().put("msg",result);
}else {
result=new String(chars1,"GBK");
result=result+"|"+new String(chars2,"GBK");
return R.error().put("msg",result);
}
} /**
* 读取二维码
* @return
*/
public static R getQRBase() throws UnsupportedEncodingException {
init(); byte[] chars1 = new byte[1024];
byte[] chars2 = new byte[1024];
NativeLong nativeLong=WINAPI.INSTANCE.GetQRBase(100,chars1,4096,chars2,4096);
String result;
if ("1".equals(nativeLong)){
result=new String(chars1,"GBK");
return R.ok().put("Content",result);
}else {
result=new String(chars1,"GBK");
return R.error().put("Content",result);
}
} public static void main(String[] args) throws UnsupportedEncodingException {
System.out.println(getSFZ());
}
}

使用JNA读取dll文件的更多相关文章

  1. C#读取DLL文件获取所有类

    说明 调用Web.dll 文件,获取其中的所有的WebService 参考 https://blog.csdn.net/huoliya12/article/details/78873123 流程 使用 ...

  2. C++读取dll文件所在目录

    ////保证config.txt从本DLL目录位置读取 //获取DLL自身所在路径(此处包括DLL文件名) }; GetModuleFileNameA((HINSTANCE)&__ImageB ...

  3. dll文件32位64位检测工具以及Windows文件夹SysWow64的坑

    自从操作系统升级到64位以后,就要不断的需要面对32位.64位的问题.相信有很多人并不是很清楚32位程序与64位程序的区别,以及Program Files (x86),Program Files的区别 ...

  4. C# 读取EXCEL文件的三种经典方法

    1.方法一:采用OleDB读取EXCEL文件: 把EXCEL文件当做一个数据源来进行数据的读取操作,实例如下: public DataSet ExcelToDS(string Path) { stri ...

  5. 自己动手写中文分词解析器完整教程,并对出现的问题进行探讨和解决(附完整c#代码和相关dll文件、txt文件下载)

    中文分词插件很多,当然都有各自的优缺点,近日刚接触自然语言处理这方面的,初步体验中文分词. 首先感谢harry.guo楼主提供的学习资源,博文链接http://www.cnblogs.com/harr ...

  6. C#生成PDF文档,读取TXT文件内容

    using System.IO;using iTextSharp.text;using iTextSharp.text.pdf; //需要在项目里引用ICSharpCode.SharpZipLib.d ...

  7. 使用jna调用dll,jdk位数和dll位数的关系

    最近在学习jna,发现dll文件能能否成功调用取决于jdk位数. 32位jdk只能使用32位的dll,64位jdk只能使用64位的dll,否则位数不对应的话报的错是 "Exception i ...

  8. C# 动态修改dll的签名 以及修改引用该dll文件的签名

    在读取RedisSessionStateProvider配置 提到用mono ceil 来修改程序集以及它的签名,里面GetPublicKey 和GetPubliKeyToken 方法里面那个字符串的 ...

  9. C# 读取压缩文件方式及乱码处理

    目前主流的压缩文件操作类,除了C#原生的.还有 1. ZIP-DotNetZip 网址:http://dotnetzip.codeplex.com/ 2 7Zip-SevenZipSharp 网址:h ...

  10. C/C++ 关于生成静态库(lib)/动态库(dll)文件如何使用(基于windows基础篇)

    1. 首先,如何制作一个静态库(lib)? 额, 对于静态库,我们知道,里头是不应该有Main函数,它只是一个配合文件.之所以称之为lib静态库,其实就是指,我们需要用到lib里头的函数时,我们才会去 ...

随机推荐

  1. 【转载】Linux虚拟化KVM-Qemu分析(四)之CPU虚拟化(2)

    原文信息: 作者:LoyenWang 出处:https://www.cnblogs.com/LoyenWang/ 公众号:LoyenWang 版权:本文版权归作者和博客园共有 转载:欢迎转载,但未经作 ...

  2. shell 编程变量使用心得

    类型 示例 用途 大写的变量名 IP 表示常量,比如,用来记录输入和输出文件名 小写变量名 mac 一般变量 左边下划线 _mac 临时的中间变量,只引用一次的变量 右边下划线 tmpfile_ 临时 ...

  3. js中调用函数中的变量

    (function f1() { var num = 10; window.num = num;})(); console.log(num);

  4. RedHat8静默安装was

    前言 was(websphere application server),类似weblogic.tomcat,由IBM开发的一种企业级Java容器. 系统版本:redhat 8.2 was版本:was ...

  5. [db2]缓冲池管理

    简介 缓冲池指的是从硬盘读取表和索引数据时,数据库管理器分配的用于高速缓存这些表和索引数据的内存区域.每个数据库都必须具有至少一个缓冲池,创建数据库时会自动创建一个名为IBMDEFAULTBP的缓冲池 ...

  6. 手写 Vuex4 源码

    本文首发于掘金,未经许可禁止转载 Vuex4 是 Vue 的状态管理工具,Vuex 和单纯的全局对象有以下两点不同: Vuex 的状态存储是响应式的 不能直接改变 store 中的状态.改变 stor ...

  7. Web通用漏洞--文件包含

    Web通用漏洞--文件包含 文件包含原理 在项目开发过程中,开发人员通常会将重复使用的函数写入单个文件中,在使用该类函数时,直接调用文件即可,无需重新编写,这种调用文件的过程成为文件包含.在文件包含过 ...

  8. [glibc2.23源码]阅读源码&调试,找出free_hook-0x13分配失败的原因

    0x00 写在前面 发freebuf了:https://www.freebuf.com/articles/endpoint/373258.html 本次阅读源码是本人第一次,算是一个全新的开始.本次看 ...

  9. cockpit--一款开源的适用于单主机的Linux监控面板

    在搜索Linux监控时,偶然发现一款还不错的监控面板,该面板为red hat开发,适用于各种Linux发行版,部署也非常方便,官方文档Running Cockpit - Cockpit Project ...

  10. java与es8实战之三:Java API Client有关的知识点串讲

    欢迎访问我的GitHub 这里分类和汇总了欣宸的全部原创(含配套源码):https://github.com/zq2599/blog_demos 本篇概览 本篇是<java与es8实战>系 ...