分享
 
 
 

JDK5.0环境下配置PKCS#11

王朝java/jsp·作者佚名  2008-05-31
窄屏简体版  字體: |||超大  

这篇文章不介绍具体的编程方法,而是针对PKCS#11的初学者介绍如何在JDK5.0环境中配置PKCS#11,具体的编程方法可以关注我的下一篇文章,或者参考PKCS#11手册以及SUN MicroSystem公司关于PKCS#11的手册。

需要的环境:

JDK5.0版本已经可以支持对PKCS#11的操作,这里就介绍一下如何实现在JDK5.0环境下配置PKCS#11,并且根据不同的操作系统提供相应的解决方案。

首先介绍一下配置环境:JDK5.0,支持标准PKCS#11的设备(包括Smartcard,加密卡等等),支持PKCS#11的系统(WINDOWS/Linux/UNIX等),以及设备供给商提供的标准PKCS#11接口。(注:PKCS#11接口只是一个动态库文件,其中封装了PKCS#11标准函数,在不同的平台上其格式不同,例如在WINDOWS上其格式是*.DLL,在LINUX上其形式是*.so)

配置方法:

在JDK5.0环境中配置访问PKCS#11的方法非常简单:只用编辑一个*.CFG文件就可以了。因为JDK5.0中已经做好了对PKCS#11的桥接。具体方法是:

1、在*.CFG文件中编辑好相应的参数和对应的值。

2、在Java语言中用Provider p = new sun.security.pkcs11.SunPKCS11(*.cfg文件的绝对路径)

3、进行相应的操作,具体的操作会在我的下一片文章中介绍。

具体*.cfg的内容以及格式是:

1、name=value 其中name是指明后面的value是该PKCS#11的名称。

2、library=*.dll/*.so的绝对路径 library后面是指明标准PKSC#11接口的绝对地址

3、description=value是该PKCS#11的注释,可以通过前面的Provider p的getInfo方法得到其值

4、slotListIndex = value/slot = value 这个标示比较非凡,假如该PKCS#11的硬件提供商提供了多个可以支持该PKCS#11的设备,那么不同设备之间必须通过不同的slot来区分,那么,在使用的时候必须明确的了解具体的硬件对应的slot的值,其中slotListIndex和slot中只用一个即可。假如在配置文件中不指明的话,那么默认的是slot=0。这时假如提供商提供了多个硬件设备,则你的程序中智能调用slot=0的那个设备。所以建议在编辑该*.cfg时添加该参数。

5、其余的参数并不是很常用,欲具体了解可以访问http://java.sun.com/j2se/1.5.0/docs/guide/security/p11guide.Html

解决方案:

跨平台时JAVA语言的一大特性,那么PKCS#11也应做到跨平台操作。当然,前提是该实现了PKCS#11接口的硬件可以跨平台(专有驱动或者是无驱型)。但由于*.cfg中指定PKCS#11接口的地址是绝对地址,所以假如想要做到跨平台就要动态的产生cfg文件了。

具体的解决方案如下:

1、首先确认该硬件可以支持当前的系统。

2、确认已经安装了相应的驱动(无驱型设备的驱动是由系统提供的)

3、确认该硬件的slotListIndex或者slot值

4、使用System.getProperty(“java.home”);获得路径,做为存储*.CFG文件的目录。取名为cfgpath

5、用JFileChooser来选择PKCS#11文件,从而获得library的值,取名为LibPath

6、建立一个FileOutputStream来存储*.CFG文件,分别写入name的值,library的值(LibPath)description的值和slotListIndex的值。这样,就可以动态的创建cfg文件了。

7、然后 就可以用Provider p = new sun.security.pkcs11.SunPkcs11(cfgpath);来加载文件,从而达到通过PKCS11来访问硬件的目的。

前面的4~7步只是一个demo,具体实施时可以根据具体的情况来改变。到此JDK5.0环境下配置PKCS#11就已经介绍完了。假如希望了解JAVA语言中的PKCS#11操作,请关注下一篇文章。

请尊重作者原创,转发时请保留作者信息

作者:鲍冠辰, 软件加密工程师 就职于 飞天诚信科技有限公司

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
2023年上半年GDP全球前十五强
 百态   2023-10-24
美众议院议长启动对拜登的弹劾调查
 百态   2023-09-13
上海、济南、武汉等多地出现不明坠落物
 探索   2023-09-06
印度或要将国名改为“巴拉特”
 百态   2023-09-06
男子为女友送行,买票不登机被捕
 百态   2023-08-20
手机地震预警功能怎么开?
 干货   2023-08-06
女子4年卖2套房花700多万做美容:不但没变美脸,面部还出现变形
 百态   2023-08-04
住户一楼被水淹 还冲来8头猪
 百态   2023-07-31
女子体内爬出大量瓜子状活虫
 百态   2023-07-25
地球连续35年收到神秘规律性信号,网友:不要回答!
 探索   2023-07-21
全球镓价格本周大涨27%
 探索   2023-07-09
钱都流向了那些不缺钱的人,苦都留给了能吃苦的人
 探索   2023-07-02
倩女手游刀客魅者强控制(强混乱强眩晕强睡眠)和对应控制抗性的关系
 百态   2020-08-20
美国5月9日最新疫情:美国确诊人数突破131万
 百态   2020-05-09
荷兰政府宣布将集体辞职
 干货   2020-04-30
倩女幽魂手游师徒任务情义春秋猜成语答案逍遥观:鹏程万里
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案神机营:射石饮羽
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案昆仑山:拔刀相助
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案天工阁:鬼斧神工
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案丝路古道:单枪匹马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:与虎谋皮
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:李代桃僵
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:指鹿为马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:小鸟依人
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:千金买邻
 干货   2019-11-12
 
推荐阅读
 
 
 
>>返回首頁<<
 
靜靜地坐在廢墟上,四周的荒凉一望無際,忽然覺得,淒涼也很美
© 2005- 王朝網路 版權所有