校园CPU卡密钥管理系统的设计与实现.pdf
《校园CPU卡密钥管理系统的设计与实现.pdf》由会员分享,可在线阅读,更多相关《校园CPU卡密钥管理系统的设计与实现.pdf(4页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、通信技术C o m m u n i c a t i o n s T e c h n o l o g i e s51前沿技术L e a d i n g-e d g e T e c h n o l o g i e s收稿日期:2 0 0 5-1 2-1 1作者简介:刘金伟,1 9 7 2 年生,男,工程师,在读博士,研究方向:计算机网络、嵌入式系统等。*“211”工程“数字工大”专项基金资助项目(05002011200201)刘金伟,黄樟钦,侯义斌,王普(北京工业大学计算机学院,北京 1 0 0 0 2 2)【摘 要】文章研究了密钥管理系统在校园一卡通系统中的应用模式。首先以CPU卡技术和密码算法
2、技术为基础,提出了一卡通系统的密钥管理系统的解决方案;然后针对系统的实现,描述了密钥分散的设计和实现过程;最后对系统中使用的算法进行了描述。密钥管理系统保证了高强度的校园一卡通系统的安全性。【关键词】CPU卡;校园一卡通;密钥管理;加密算法【中图分类号】TP309 【文献标识码】A 【文章编号】1009-8054(2006)10-0051-04Design and Implementation of Key Management System of Campus CPU Card SystemLiu Jinwei,Huang Zhangqin,Hou Yibin,Wang Pu(College
3、 of Computer Science,Beijing University of Technology,Beijing 100022,China)【Abstract】In this paper,it is devoted to the study of application of the key management system,which exampled withthe implementation of the key management system in Campus E-Card System.First,the issue brings forward the reso
4、lu-tion of the smart card encryption key management system for the Campus E-Card System based on CPU card technologyand encryption algorithm.The design and implementation of the encryption key diversify are described.Then the algo-rithm used in the system.And it assured the safety of Campus E-Card s
5、ystem.【Keywords】CPU card;campus e-card;key management;cryptographic algorithm校园 C P U卡密钥管理系统的设计与实现*1 引言校园一卡通系统是一个多功能IC卡应用系统,如食堂收费、学生成绩管理、图书馆借阅等,对提高工作效率和管理水平、减少现金流通等方面都大有益处。对于校园一卡通系统,用密码技术保护系统的安全取决于对密钥的保护,密钥管理系统是整个IC卡应用系统安全的核心,密钥系统的管理和控制是IC卡应用系统的关键,密钥管理系统的安全性将直接影响整个应用系统的安全性。校园一卡通项目中采用双界面CPU卡作为加密和存储介质
6、,CPU卡的加密解密功能由内嵌的硬件加密协处理器来实现,具有很高的安全性,按照对称加密体制设计和实现了一种新型密钥管理系统。系统中的密钥涉及到两部分:一部分是由银行负责产生并维护的密钥,另一部分由校园一卡通系统中的密钥管理系统产生,并由校方进行维护。密钥管理系统符合PBOC的密钥管理规范1。2 密钥系统的设计与实现密钥管理包括密钥的生成、装入、传递、存储、恢复、销毁等内容。密钥管理系统中使用的密钥都是双倍长度的密钥(16字节),交易过程中使用的过程密钥都是单倍长度(8字节)。一卡通生成的主密钥称为根密钥,标志为G*K,主要有消费/取现共享密钥。一卡通生成和使用的密钥称为主密钥,标志为M*K。用
7、户卡使用的经过主密钥分散的密钥称为用户卡密钥,标志为D*K。用户卡交易过程中使用的过程密钥标志为S*K。系统利用密钥卡来承载密钥,密钥卡在一卡通密钥管理系统内、一卡通和一卡通、一卡通和用户卡之间进行安全传递。2.1 密钥类型在密钥管理系统中的密钥可分为三大类:一卡通共享密钥、一卡通专有密钥和管理密钥2。一卡通共享密钥由一卡通C o m m u n i c a t i o n s T e c h n o l o g i e s通信技术52L e a d i n g-e d g e T e c h n o l o g i e s前沿技术生成和维护,安全存放在一卡通的母卡A和母卡B中。消费/取现根密
8、钥是一卡通共享主密钥,用于PBOC卡的取现/消费交易。一卡通专有密钥由一卡通生成和维护,安全存放在一卡通的母卡A和母卡B中。一卡通生成其它交易使用的主密钥,包括部分PBOC卡片的维护密钥。管理密钥有两种作用:作为认证密钥和保护密钥。认证密钥用来对卡片做外部认证的,一般记为ADMK。保护密钥是用来对主密钥进行加密保护注入到卡片或输出到另一张卡片。2.2 密钥的索引每张用户卡含有两组密钥,用两个索引值来区分,正常时使用第一索引的密钥,异常情况下(如密钥泄露)启用第二索引。此机制保证在异常情况下更换密钥时,不需收回已发出的用户卡,只需将应用系统(包括PSAM)中的密钥更新为新的索引。每个版本的消费/
9、取现根密钥含有两个索引,预留两个索引作为根密钥的备用索引,所以,消费/取现密钥采用4个索引。2.3 密钥卡的分类为了将共享密钥安全地传递到各个子系统,一卡通密钥管理系统采用几种密钥卡来实现。密钥卡分为三类:母卡、控制卡和认证卡。母卡里存放着一卡通生成的专有密钥,一卡通的母卡由母卡A和母卡B实现,只有同时持有A、B卡,才可以将主密钥导出。发卡母卡里存放着一卡通的消费/取现主密钥,一卡通将专有密钥注入发卡母卡,利用该卡将消费/取现密钥、圈存圈提等密钥注入用户卡。控制卡里的主密钥是有输出次数控制的,一卡通密钥管理系统里有总控卡、HSAM控制卡、PSAM控制卡三种。总控卡的主密钥由一卡通母卡A和母卡B
10、导入;HSAM控制卡、PSAM控制卡是总控卡的子卡。认证密钥卡的主密钥文件里存放着密钥卡的认证密钥,有一卡通操作员卡和一卡通认证密钥卡两种。一卡通操作员卡是一卡通制卡员持有的制卡“钥匙”,操作卡里存放着一卡通密钥卡的管理密钥,可以对密钥卡的管理密钥进行认证修改,用一卡通认证密钥卡来验证一卡通所发下来的卡是否正确,并可以修改该卡的管理密钥。2.4 系统结构密钥管理系统包含的主要功能模块有:密钥生成模块;密钥传递模块;用户卡发卡;PSAM卡管理系统模块;测试发卡(附加功能模块);一卡通交易测试系统(附加功能模块);密钥的应用关系。图1所示的为密钥管理系统发卡过程中卡片产生的主要流程。(1)密钥生成
11、模块。利用密钥生成模块来生成所需的主密钥,包括:消费主密钥;圈存、圈提主密钥;解锁(PIN)主密钥、重装(PIN)主密钥;修改主密钥,应用维护主密钥;TAC主密钥。一卡通主密钥由种子A和B、系统的随机数决定生成,生成的主密钥分别注入到母卡A、母卡B中,母卡A和母卡B由校领导保存,并持有该卡的PIN。主密钥的生成算法为:输入种子A和种子B后,产生一个随机数RAND,该随机数固定在这个生成模块上。KEY1=3DES(SEEDA|SEEDB,RAND)主密钥检查该KEY的强度,若合格则作为候选的主密钥输出;若不合格,RAND=RAND+1,继续产生KEY1,直到产生合格的主密钥。KEY2=3DES(
12、SEEDA|SEEDB,RAND+)产生KEY2,直到输出外界所需个数的主密钥。系统可以采用KG卡来实现这一个过程,如图2所示。主密钥生成后,注入到母卡A和母卡B中。必须同时持有母卡A、母卡B及密钥卡的密码,才可以导出其中的主密钥。(2)密钥传递模块。利用图2所表示的密钥生成模块,两位校领导分别在密钥系统上输入种子A、B,密钥系统生成一卡通系统所需的密钥,并分别保存在母卡A和母卡B中。为了便于使用,密钥系统将母卡A、B的密钥合成在一张总控卡中,通过总控卡,密钥系统分别制作出三种不同的密钥卡,如图3所示。发卡母卡和发卡控制卡交给发卡机构(银行或公司);主机HSAM卡内的密钥(圈存密钥等)通过安全
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 校园 CPU 密钥 管理 系统 设计 实现
限制150内