CN102842005A - 一种基于tsm的tspi接口的csp模块和csp实现方法 - Google Patents

一种基于tsm的tspi接口的csp模块和csp实现方法 Download PDF

Info

Publication number
CN102842005A
CN102842005A CN2011101662725A CN201110166272A CN102842005A CN 102842005 A CN102842005 A CN 102842005A CN 2011101662725 A CN2011101662725 A CN 2011101662725A CN 201110166272 A CN201110166272 A CN 201110166272A CN 102842005 A CN102842005 A CN 102842005A
Authority
CN
China
Prior art keywords
key
csp
interface
tspi
module
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Granted
Application number
CN2011101662725A
Other languages
English (en)
Other versions
CN102842005B (zh
Inventor
艾俊
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Nationz Technologies Inc
Original Assignee
Nationz Technologies Inc
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by Nationz Technologies Inc filed Critical Nationz Technologies Inc
Priority to CN201110166272.5A priority Critical patent/CN102842005B/zh
Publication of CN102842005A publication Critical patent/CN102842005A/zh
Application granted granted Critical
Publication of CN102842005B publication Critical patent/CN102842005B/zh
Active legal-status Critical Current
Anticipated expiration legal-status Critical

Links

Images

Landscapes

  • Storage Device Security (AREA)

Abstract

本发明涉及一种基于TSM的TSPI接口的CSP模块和CSP实现方法,主要包括基于TSM的TSPI接口创建的CSP连接接口、CSP密钥生成和交换接口、CSP加解密接口和CSP哈希和数字签名接口。其中,CSP连接接口用于进行CSP密钥容器的获取与清除、容器参数的设置与获取以及释放所述CSP密钥容器;CSP密钥生成和交换接口用于进行CSP产生与销毁密钥对象、导入导出密钥对象、加载密钥对象、获取与设置密钥对象参数以及生成随机数;CSP加解密接口用于进行CSP加密和解密;所述CSP哈希和数字签名接口用于产生与销毁哈希对象、获取与设置哈希对象参数、签名和验签。通过在TSM接口TSPI上封装上述接口,可以方便安全应用开发者快速开发TCM应用,同时方便传统应用快速移植到TCM上来。

Description

一种基于TSM的TSPI接口的CSP模块和CSP实现方法
技术领域
本发明涉及可信计算领域,特别涉及应用可信计算技术实现Microsoft CryptoAPI(微软公司所提供的应用程序编程接口,提供了一组函数,这些函数允许应用程序在对用户的敏感私钥数据提供保护时以灵活的方式对数据进行加密或数字签名)加密标准的CSP(Cryptographic Service Provider,加密服务提供者)的***和方法。
背景技术
可信密码模块(Trusted Cryptography Module,TCM)是可信计算密码支撑平台必备的关键基础部件,提供独立的密码算法运算功能,支撑可信计算平台功能体系建立。
TCM构建了一个具有存储保护和执行保护的子***,该子***为计算平台建立信任根基,其独立的计算资源将建立严格受限的安全保护机制。为有效发挥TCM功能体系作用,将子***中需执行保护的函数与无需执行保护的函数划分开,将无需执行保护的功能函数由计算平台主处理器执行,而这些支持函数构成了TCM服务模块,记为TSM(Trusted Services Module,可信服务模块)。
TSM作为TCM的软件协议栈,提供规范化的函数接口,而面向应用程序的TCM服务调用接口TSPI(TSM Service Provider Interface,TSM服务提供者接口),分10类120个接口函数,可以为可信计算密码应用程序开发提供指导和调用。但由于目前大多数安全应用所采用的密码服务调用接口类型主流是CSP、CNG(Cryptography API: Next Generation下一代加密技术)和PKCS#11(PKCS#11是一个加密标准),大多数应用开发者熟悉和习惯CSP、CNG和PKCS#11接口调用模式,并且已建立成熟的产品开发支持体系。
当传统安全应用的开发者转向基于TCM密码服务功能而进行应用开发时,需要重新学习TCM密码服务调用接口体系(TSPI),另外,更为甚者,传统安全应用要移植到TCM上,必须全部重新开发,给应用厂商带来资源消耗,这为TCM应用推广带来很大阻力。
发明内容
本发明所要解决的技术问题是提供一种基于TSM的TSPI接口的CSP模块,以方便安全应用开发者快速开发TCM应用,同时方便传统应用快速移植到TCM上来。
本发明解决上述技术问题的技术方案如下:
一种基于TSM的TSPI接口的CSP模块,包括:
TCM芯片、所述TCM芯片的TSM、所述TSM的调用接口TSPI,以及基于所述TSPI创建的CSP连接接口、CSP密钥生成和交换接口、CSP加解密接口和CSP哈希和数字签名接口;其中
所述CSP连接接口用于进行CSP密钥容器的获取与清除、容器参数的设置与获取以及释放所述CSP密钥容器;
所述CSP密钥生成和交换接口用于进行CSP产生与销毁密钥对象、导入导出密钥对象、加载密钥对象、获取与设置密钥对象参数以及生成随机数;
所述CSP加解密接口用于进行CSP加密和解密;
所述CSP哈希和数字签名接口用于产生与销毁哈希对象、获取与设置哈希对象参数、签名和验签。
进一步,所述CSP连接接口包括:
CSP环境获取模块:用于指定CSP,返回CSP密钥容器的句柄,获取TCM芯片SMK(Storage Master Key,存储主密钥)对象和TCM对象,并以SMK为父密钥生成SM2(一种非对称加解密算法)的容器密钥,该SM2容器密钥是后续所有密钥的父密钥;
密钥容器释放模块:用于销毁CSP密钥容器句柄;
CSP属性设置模块:用于设置CSP的属性;
CSP属性获取模块:用于获取CSP的属性。
进一步,所述密钥在TCM芯片的硬件中生成和存储,并结合计算机的存储和计算资源为所述CSP密钥进行硬件保护。
进一步,所述CSP密钥生成和交换接口包括:
密钥产生模块:用于产生密钥;
密钥对象生成模块:用于生成密钥对象;
密钥销毁模块:用于销毁已产生的密钥;
密钥导出模块:用于导出密钥,使其产生一个副本密钥;
密钥导入模块:用于导入副本密钥到CSP中;
密钥参数获取模块:用于获取密钥参数;
密钥参数设置模块:用于设置密钥参数;
随机数产生模块:用于产生随机数。
进一步,所述密钥导出模块调用的TSPI接口包括:
Tspi密钥数据加载接口,用于加载指定的密钥数据块加载到TCM中;
Tspi迁移票据提供接口,用于提供迁移过程的迁移票据;
Tspi密钥迁移数据块创建接口,用于创建当前密钥的迁移数据块;
Tspi密钥数据块卸载接口,用于卸载已加载到TCM中的密钥数据块。
进一步,所述密钥导入模块调用的TSPI接口包括:
Tspi密钥对象创建接口,用于创建一个密钥对象;
Tspi策略对象分配接口,用于为密钥对象绑定策略对象;
Tspi密钥对象数据设置接口,用于设置密钥对象的数据;
Tspi数据块转换接口,用于将迁移数据块转换为普通密钥数据块。
进一步,所述随机数产生模块调用的TSPI接口包括:
Tspi随机数生成接口,用于生成随机数。
进一步,所述CSP加解密接口包括: 
数据加密模块:用于数据加密;
数据解密模块:用于数据解密。
进一步,所述CSP哈希和数字签名接口包括:
哈希对象生成模块:用于产生空的哈希对象;
散列值产生模块:用于产生给定数据的散列值;
哈希对象参数获取模块:用于获取哈希对象的参数;
哈希对象参数设置模块:用于设置哈希对象的参数;
哈希对象销毁模块:用于销毁哈希对象;
哈希值产生模块:用于对密钥对象产生哈希值;
哈希对象签名模块:用于对指定的哈希对象进行签名;
签名验证模块:用于对签名进行验证。
进一步,所述哈希对象签名模块调用的TSPI接口包括:
Tspi哈希值更新接口,用于更新哈希对象的哈希值;
签名密钥句柄获取接口,用于获取签名密钥句柄;
Tspi密钥加载接口,用于加载签名密钥到TCM中;
Tspi哈希值签名接口,用于使用签名密钥对哈希对象的哈希值做签名;
Tspi密钥数据块卸载接口,用于卸载已加载到TCM中的密钥数据块;
签名密钥对象释放接口,用于释放签名密钥对象。
进一步,所述签名验证模块调用的TSPI接口包括:
Tspi签名验证接口,用于对签名进行验证。
本发明还提供了一种基于TSM的TSPI接口的CSP实现方法,包括:
通过CSP连接接口进行CSP密钥容器的获取与清除、容器参数的设置与获取以及释放所述CSP密钥容器;
通过CSP密钥生成和交换接口进行CSP产生与销毁密钥对象、导入导出密钥对象、加载密钥对象、获取与设置密钥对象参数以及生成随机数;
通过CSP加解密接口进行CSP加密和解密;
通过CSP哈希和数字签名接口进行哈希对象的产生与销毁、哈希对象参数、签名和验签的获取与设置。
本发明的有益效果在于,通过在TSM接口TSPI上封装CSP连接接口、CSP密钥生成和交换接口、CSP加解密接口和CSP哈希和数字签名接口,可以方便安全应用开发者快速开发TCM应用,同时方便传统应用快速移植到TCM上来。
附图说明
图1为本发明中的基于TSM的TSPI接口的CSP密码服务体系结构图;
图2为本发明基于TSM的TSPI接口的CSP密码服务体系的密钥层次图;
图3为设置签名密钥或者交换密钥使用授权的流程图;
图4为使用签名密钥或交换密钥授权的流程图。
具体实施方式
以下结合附图对本发明的原理和特征进行描述,所举实例只用于解释本发明,并非用于限定本发明的范围。
如图1所示,本发明的基于TSM的TSPI接口的CSP密码服务体系,在TCM模块的TSM的基础上,利用TCM服务调用接口TSPI开发出一套新的CSP接口,通过该CSP接口,程序开发者开发的应用程序可以直接利用微软公司的CryptoSPI来使用本发明提供的CSP的加密服务。程序开发者不需要重新学***台的存储和计算机资源为算法和密钥提供基于硬件的保护。
本发明的基于TSM的TSPI接口的CSP密码服务体系中的CSP接口包括如下。
基于TSM的TSPI接口,创建CSP连接接口,该CSP连接接口用于进行CSP密钥容器的获取与清除、容器参数的设置与获取以及释放所述CSP密钥容器。
该步骤在产生CSP密钥容器时,为每个CSP密钥容器产生一个与其对应的容器密钥,该容器密钥为以SMK为父密钥的SM2密钥,同时也是后续CSP为该CSP密钥容器产生的所有密钥的父密钥。CSP密钥容器的信息和CSP容器密钥的UUID(Universally Unique Identifiers,全局唯一标识符)信息可以保存在TCM芯片的NV(Non-volatile Storage,非易失性存储区)存储区或者操作***的注册表中。
上述CSP连接接口包括以下函数:
CPAcquireContext函数:用于指定CSP,返回CSP密钥容器的句柄,获取TCM芯片SMK对象和TCM对象,并以SMK为父密钥生成SM2的容器密钥,该SM2容器密钥是后续所有密钥的父密钥,密钥的层次结构如图2所示;
CPReleaseContext函数:用于销毁CSP密钥容器句柄;
CPSetProvParam函数:用于设置CSP的属性;
CPGetProvParam函数:用于获取CSP的属性。
其中,CPAcquireContext函数的具体实现如下:
构建TSP上下文及全局对象,调用的TSPI接口包括:
Tspi_Context_Create(),用于构造TSP上下文;
Tspi_Context_Connect(),用于连接TCS;
Tspi_Context_GetTCMObject(),用于获取TCM芯片对象;
Tspi_Context_CreateObject(),用于生成SMK对象、默认为Policy对象;
Tspi_Policy_SetSecret(),用于设置授权数据;
Tspi_Policy_AssignToObject(),用于给需要授权的对象绑定策略对象;
根据容器参数操作密钥集;
记录环境配置,返回容器句柄。
CPReleaseContext函数的具体实现如下:
释放未能正常释放的资源,包括密钥对象与哈希对象,调用的TSPI接口包括:
Tspi_Context_CloseObject(),用于销毁上下文对象句柄所关联的对象,释放该对象的相关资源;
Tspi_Policy_FlushSecret(),用于清空授权对象的授权数据;
Tspi_Context_CloseObject(),用于销毁SMK对象、默认为Policy对象;
Tspi_Context_Close(),用于断开与TCS的连接,销毁上下文对象;
删除当前环境配置记录。
CPSetProvParam函数,如图3、图4所示通过设置签名密钥或交换密钥授权数据参数设置签名密钥或交换密钥的授权数据或使用授权数据。同时,通过设置修改签名密钥或交换密钥授权数据参数更改相应密钥的授权数据。
基于TSM的TSPI接口,创建CSP密钥生成和交换接口,该CSP密钥生成和交换接口用于进行CSP产生与销毁密钥对象、导入导出密钥对象、加载密钥对象、获取与设置密钥对象参数以及生成随机数。
该步骤中,密钥在TCM芯片硬件中生成、存储和管理,并可以结合计算机***平台的存储和计算资源为算法和CSP密钥提供硬件保护。在生成签名密钥或者交换密钥前,调用了设置容器签名密钥口令或者交换密钥口令将生成带有指定授权的相应密钥,以后再次使用该密钥需要设置密钥的使用授权。
密钥的导入导出功能是两个可信平台之间的安全密钥迁移,在使用密钥的导入导出功能时,将验证TCM芯片的Owner授权,只有Owner授权成功才能完成密钥的导入导出,Owner授权不成功则不能完成密钥的导入导出,设置Owner授权通过调用设置容器TCM芯片所有者授权参数完成。
上述CSP密钥生成和交换接口包括以下函数:
CPDeriveKey函数:用于产生密钥;
CPGenKey函数:用于生成密钥对象;
CPDestroyKey函数:用于销毁已产生的密钥;
CPExportKey函数:用于导出密钥,使其产生一个副本密钥;
CPImportKey函数:用于导入副本密钥到CSP中;
CPGetKeyParam函数:用于获取密钥参数;
CPSetKeyParam函数:用于设置密钥参数;
CPGenRandom函数:用于产生随机数。
其中,CPDeriveKey函数的具体实现如下:
取哈希对象的哈希值,调用的TSPI接口包括:
Tspi_Hash_GetHashValue(),用于获得哈希对象的哈希值;
Tspi_Context_CreateObject(),用于创建密钥对象;
Tspi_Policy_AssignToObject(),用于为密钥对象分配策略对象;
使用哈希值填充密钥数据,调用的TSPI接口包括:
Tspi_SetAttribData(),用于设置密钥对象的数据内容;
生成SMS4密钥,调用的TSPI接口包括:
Tspi_Key_WrapKey(),用于包裹密钥对象;
设置密钥对象访问权限;
记录密钥对象,并返回它的句柄。
CPGenKey函数的具体实现如下:
生成密钥对象,调用的TSPI接口包括:
Tspi_Context_CreateObject(),用于创建密钥对象;
Tspi_Policy_AssignToObject(),用于为密钥对象分配策略对象;
Tspi_Key_CreateKey(),用于创建密钥对,并用父密钥进行包裹;
设置密钥访问权限;
若生成的是非对称密钥,则在密钥数据库中注册,调用的TSPI接口包括:
Tspi_Context_RegisterKey(),用于在密钥数据库中注册密钥;
记录该密钥,并返回它的句柄。
CPDestroyKey函数的具体实现如下:
关闭密钥对象,调用的TSPI接口包括:
Tspi_Context_CloseObject(),用于销毁一个密钥对象句柄所关联的对象,释放该对象的相关资源;
删除该密钥记录。
CPExportKey函数调用的TSPI接口和具体实现如下:
Tspi_Key_LoadKey(),用于加载指定的密钥数据块加载到TCM中;
Tspi_Key_AuthorizeMigrationKey(),用于提供迁移过程的迁移票据;
Tspi_Key_CreateMigrationBlob(),用于创建当前密钥的迁移数据块;
Tspi_Key_UnLoadKey(),用于卸载已加载到TCM中的密钥数据块。
CPImportKey函数调用的TSPI接口和具体实现如下:
Tspi_Context_Create(),用于创建一个密钥对象;
Tspi_Policy_AssignToObject(),用于为密钥对象绑定策略对象;
Tspi_SetAttribData(),用于设置密钥对象的数据;
Tspi_Key_ConvertMigrationBlob(),用于将迁移数据块转换为普通密钥数据块。
CPGenRandom函数调用的TSPI接口和具体实现如下:
Tspi_TCM_GetRandom(),用于生成随机数。
基于TSM的TSPI接口,创建CSP加解密接口,所述CSP加解密接口用于进行CSP加密和解密。
通过该步骤中的CSP加解密接口,在TCM芯片内部进行数据的加解密,若使用的交换密钥设置了授权,则TCM芯片验证交换密钥的授权数据。
上述CSP加解密接口包括:
CPEncrypt函数:用于数据加密;
CPDecrypt函数:用于数据解密。
其中,CPEncrypt函数的具体实现如下:
对明文数据进行哈希计算,调用的TSPI接口包括:
Tspi_Hash_UpdateHashValue(),用于更新哈希对象的哈希值;
对明文数据进行加密,调用的TSPI接口包括:
Tspi_Context_CreateObject(),用于创建加密对象;
Tspi_Key_LoadKey(),用于加载加密密钥到TCM中;
Tspi_Data_Encrypt(),用于对明文数据进行加密;
Tspi_Key_UnLoadKey(),用于卸载已加载到TCM中的密钥数据块;
Tspi_GetAttribData(),用于获取加密对象的加密数据块;
Tspi_Context_CloseObject(),用于销毁一个加密对象句柄所关联的对象,释放该对象的相关资源。
CPDecrypt函数的具体实现如下:
对密文数据进行解密,调用的TSPI接口包括:
Tspi_Context_CreateObject(),用于创建加密对象;
Tspi_SetAttribData(),用于设置加密对象的加密数据块;
Tspi_Key_LoadKey(),用于加载解密密钥到TCM中;
Tspi_Data_Decrypt(),用于对密文数据进行解密;
Tspi_Key_UnLoadKey(),用于卸载已加载到TCM中的密钥数据块;
Tspi_Context_CloseObject(),用于销毁一个加密对象句柄所关联的对象,释放该对象的相关资源;
若哈希对象存在,则对经过解密后的明文数据进行哈希计算,调用的TSPI接口包括:
Tspi_Hash_UpdateHashValue(),用于更新哈希对象的哈希值。
基于TSM的TSPI接口创建CSP哈希和数字签名接口,该CSP哈希和数字签名接口用于产生与销毁哈希对象、获取与设置哈希对象参数、签名和验签。
通过该CSP哈希和数字签名接口,在TCM芯片内部进行数据签名,若使用的签名密钥设置了授权,则TCM芯片验证签名密钥的授权数据。
上述CSP哈希和数字签名接口包括以下函数: 
CPCreateHash函数:用于产生空的哈希对象;
CPHashData函数:用于产生给定数据的散列值;
CPGetHashParam函数:用于获取哈希对象的参数;
CPSetHashParam函数:用于设置哈希对象的参数;
CPDestroyHash函数:用于销毁哈希对象;
CPHashSessionKey函数:用于对密钥对象产生哈希值;
CPSignHash函数:用于对指定的哈希对象进行签名;
CPVerifySignature函数:用于对签名进行验证。
其中,CPCreateHash函数的具体实现如下:
生成哈希对象,调用的TSPI接口包括:
Tspi_Context_CreateObject(),用于创建一个哈希对象;
记录该哈希对象,并返回它的句柄。
CPHashData函数的具体实现如下:
将数据追加到TSM哈希对象中,调用的TSPI接口包括:
Tspi_Hash_UpdateHashValue(),用于更新哈希对象的哈希值。
CPDestroyHash函数的具体实现如下:
关闭TSM哈希对象,调用的TSPI接口包括:
Tspi_Context_CloseObject(),用于销毁一个哈希对象句柄所关联的对象,释放该对象的相关资源;
删除该哈希对象记录。
CPHashSessionKey函数的具体实现如下:
取会话密钥的BLOB进行哈希计算,调用的TSPI接口包括:
Tspi_GetAttribData(),用于获取会话密钥的加密数据块;
Tspi_Hash_UpdateHashValue(),用于更新哈希对象的哈希值。
CPSignHash函数调用的TSPI接口如下:
Tspi_Hash_UpdateHashValue(),用于更新哈希对象的哈希值;
CPGetUserKey(),用于获取签名密钥句柄;
Tspi_Key_LoadKey,用于加载签名密钥到TCM中;
Tspi_Hash_Sign(),用于使用签名密钥对哈希对象的哈希值做签名;
Tspi_Key_UnloadKey(),用于卸载已加载到TCM中的密钥数据块;
CPDestroyKey(),用于释放签名密钥对象。
CPVerifySignature函数调用的TSPI接口和具体实现如下:
Tspi_Hash_VerifySignature(),用于对签名进行验证。
本发明利用TCM芯片、基于TCM芯片的TSM中的调用接口TSPI,开发出上述CSP连接接口、CSP密钥生成和交换接口、CSP加解密接口和CSP哈希和数字签名接口。提供了一个硬件的CSP,该CSP中所有的密钥都在TCM芯片内部产生,加解密操作和签名验签操作都是在TCM芯片内部完成,在使用CSP中的非对称密钥的私钥时都需要进行授权认证,保证了CSP密钥的安全性。并且,上述函数名称和用途与现有CSP中函数的名称和用途一致,因此,安全应用开发者不必重新学习TCM密码服务调用接口体系(TSPI)便可以利用本发明提供的硬件的CSP,也方便了传统应用快速移植到TCM上来,减小了TCM应用推广的阻力。
以上所述仅为本发明的较佳实施例,并不用以限制本发明,凡在本发明的精神和原则之内,所作的任何修改、等同替换、改进等,均应包含在本发明的保护范围之内。

Claims (12)

1. 一种基于TSM的TSPI接口的CSP模块,其特征在于,包括:
TCM芯片、所述TCM芯片的TSM、所述TSM的调用接口TSPI,以及基于所述TSPI创建的CSP连接接口、CSP密钥生成和交换接口、CSP加解密接口和CSP哈希和数字签名接口;其中
所述CSP连接接口用于进行CSP密钥容器的获取与清除、容器参数的设置与获取以及释放所述CSP密钥容器;
所述CSP密钥生成和交换接口用于进行CSP产生与销毁密钥对象、导入导出密钥对象、加载密钥对象、获取与设置密钥对象参数以及生成随机数;
所述CSP加解密接口用于进行CSP加密和解密;
所述CSP哈希和数字签名接口用于产生与销毁哈希对象、获取与设置哈希对象参数、签名和验签。
2.根据权利要求1所述的基于TSM的TSPI接口的CSP模块,其特征在于,所述CSP连接接口包括:
CSP环境获取模块:用于指定CSP,返回CSP密钥容器的句柄,获取TCM芯片SMK对象和TCM对象,并以SMK为父密钥生成SM2的容器密钥,该SM2容器密钥是后续所有密钥的父密钥;
密钥容器释放模块:用于销毁CSP密钥容器句柄;
CSP属性设置模块:用于设置CSP的属性;
CSP属性获取模块:用于获取CSP的属性。
3.根据权利要求1所述的基于TSM的TSPI接口的CSP模块,其特征在于:所述密钥在TCM芯片的硬件中生成和存储,并结合计算机的存储和计算资源为所述CSP密钥进行硬件保护。
4.根据权利要求1所述的基于TSM的TSPI接口的CSP模块,其特征在于,所述CSP密钥生成和交换接口包括:
密钥产生模块:用于产生密钥;
密钥对象生成模块:用于生成密钥对象;
密钥销毁模块:用于销毁已产生的密钥;
密钥导出模块:用于导出密钥,使其产生一个副本密钥;
密钥导入模块:用于导入副本密钥到CSP中;
密钥参数获取模块:用于获取密钥参数;
密钥参数设置模块:用于设置密钥参数;
随机数产生模块:用于产生随机数。
5.根据权利要求4所述的基于TSM的TSPI接口的CSP模块,其特征在于,所述密钥导出模块调用的TSPI接口包括:
Tspi密钥数据加载接口,用于加载指定的密钥数据块加载到TCM中;
Tspi迁移票据提供接口,用于提供迁移过程的迁移票据;
Tspi密钥迁移数据块创建接口,用于创建当前密钥的迁移数据块;
Tspi密钥数据块卸载接口,用于卸载已加载到TCM中的密钥数据块。
6.根据权利要求4所述的基于TSM的TSPI接口的CSP模块,其特征在于,所述密钥导入模块调用的TSPI接口包括:
Tspi密钥对象创建接口,用于创建一个密钥对象;
Tspi策略对象分配接口,用于为密钥对象绑定策略对象;
Tspi密钥对象数据设置接口,用于设置密钥对象的数据;
Tspi数据块转换接口,用于将迁移数据块转换为普通密钥数据块。
7.根据权利要求4所述的基于TSM的TSPI接口的CSP模块,其特征在于,所述随机数产生模块调用的TSPI接口包括:
Tspi随机数生成接口,用于生成随机数。
8.根据权利要求1所述的基于TSM的TSPI接口的CSP模块,其特征在于,所述CSP加解密接口包括:
数据加密模块:用于数据加密;
数据解密模块:用于数据解密。
9.根据权利要求1所述的基于TSM的TSPI接口的CSP模块,其特征在于,所述CSP哈希和数字签名接口包括:
哈希对象生成模块:用于产生空的哈希对象;
散列值产生模块:用于产生给定数据的散列值;
哈希对象参数获取模块:用于获取哈希对象的参数;
哈希对象参数设置模块:用于设置哈希对象的参数;
哈希对象销毁模块:用于销毁哈希对象;
哈希值产生模块:用于对密钥对象产生哈希值;
哈希对象签名模块:用于对指定的哈希对象进行签名;
签名验证模块:用于对签名进行验证。
10.根据权利要求9所述的基于TSM的TSPI接口的CSP模块,其特征在于,所述哈希对象签名模块调用的TSPI接口包括:
Tspi哈希值更新接口,用于更新哈希对象的哈希值;
签名密钥句柄获取接口,用于获取签名密钥句柄;
Tspi密钥加载接口,用于加载签名密钥到TCM中;
Tspi哈希值签名接口,用于使用签名密钥对哈希对象的哈希值做签名;
Tspi密钥数据块卸载接口,用于卸载已加载到TCM中的密钥数据块;
签名密钥对象释放接口,用于释放签名密钥对象。
11.根据权利要求9所述的基于TSM的TSPI接口的CSP模块,其特征在于,所述签名验证模块调用的TSPI接口包括:
Tspi签名验证接口,用于对签名进行验证。
12.基于TSM的TSPI接口的CSP实现方法,包括:
通过CSP连接接口进行CSP密钥容器的获取与清除、容器参数的设置与获取以及释放所述CSP密钥容器;
通过CSP密钥生成和交换接口进行CSP产生与销毁密钥对象、导入导出密钥对象、加载密钥对象、获取与设置密钥对象参数以及生成随机数;
通过CSP加解密接口进行CSP加密和解密;
通过CSP哈希和数字签名接口进行哈希对象的产生与销毁、哈希对象参数、签名和验签的获取与设置。
CN201110166272.5A 2011-06-21 2011-06-21 一种基于tsm的tspi接口的csp模块和csp实现方法 Active CN102842005B (zh)

Priority Applications (1)

Application Number Priority Date Filing Date Title
CN201110166272.5A CN102842005B (zh) 2011-06-21 2011-06-21 一种基于tsm的tspi接口的csp模块和csp实现方法

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
CN201110166272.5A CN102842005B (zh) 2011-06-21 2011-06-21 一种基于tsm的tspi接口的csp模块和csp实现方法

Publications (2)

Publication Number Publication Date
CN102842005A true CN102842005A (zh) 2012-12-26
CN102842005B CN102842005B (zh) 2015-06-10

Family

ID=47369355

Family Applications (1)

Application Number Title Priority Date Filing Date
CN201110166272.5A Active CN102842005B (zh) 2011-06-21 2011-06-21 一种基于tsm的tspi接口的csp模块和csp实现方法

Country Status (1)

Country Link
CN (1) CN102842005B (zh)

Cited By (8)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN102831360A (zh) * 2012-08-06 2012-12-19 江苏敏捷科技股份有限公司 个人电子文件安全管理***及其管理方法
CN103138938A (zh) * 2013-03-22 2013-06-05 中金金融认证中心有限公司 基于csp的sm2证书申请及应用方法
CN104052596A (zh) * 2013-03-11 2014-09-17 江苏国盾科技实业有限责任公司 一种基于sm2算法的应用服务***
CN105871539A (zh) * 2016-03-18 2016-08-17 华为技术有限公司 一种密钥处理方法及装置
CN106096446A (zh) * 2016-06-15 2016-11-09 北京工业大学 一种可信计算环境中密码服务接口的封装方法
CN104050426B (zh) * 2014-06-12 2017-03-22 南京理工大学 一种基于tcm的涉密信息移植***
CN106775656A (zh) * 2016-11-28 2017-05-31 江西金格科技股份有限公司 一种基于多智能密钥盘的调度方法
CN114385248A (zh) * 2020-10-22 2022-04-22 四零四科技股份有限公司 处理信任链的计算***及装置

Citations (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN1449527A (zh) * 2000-06-28 2003-10-15 微软公司 共享名
CN101447010A (zh) * 2008-12-30 2009-06-03 北京飞天诚信科技有限公司 登录***及登录方法
CN102055759A (zh) * 2010-06-30 2011-05-11 北京飞天诚信科技有限公司 一种硬件引擎的实现方法

Patent Citations (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN1449527A (zh) * 2000-06-28 2003-10-15 微软公司 共享名
CN101447010A (zh) * 2008-12-30 2009-06-03 北京飞天诚信科技有限公司 登录***及登录方法
CN102055759A (zh) * 2010-06-30 2011-05-11 北京飞天诚信科技有限公司 一种硬件引擎的实现方法

Non-Patent Citations (1)

* Cited by examiner, † Cited by third party
Title
国家密码管理局: "可信计算密码支撑平台功能与接口规范", 《HTTP://GM.GD.GOV.CN/UPFILE/2009113103555609.PDF》 *

Cited By (13)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN102831360B (zh) * 2012-08-06 2015-01-28 江苏敏捷科技股份有限公司 个人电子文件安全管理***及其管理方法
CN102831360A (zh) * 2012-08-06 2012-12-19 江苏敏捷科技股份有限公司 个人电子文件安全管理***及其管理方法
CN104052596A (zh) * 2013-03-11 2014-09-17 江苏国盾科技实业有限责任公司 一种基于sm2算法的应用服务***
CN103138938A (zh) * 2013-03-22 2013-06-05 中金金融认证中心有限公司 基于csp的sm2证书申请及应用方法
CN103138938B (zh) * 2013-03-22 2016-01-20 中金金融认证中心有限公司 基于csp的sm2证书申请及应用方法
CN104050426B (zh) * 2014-06-12 2017-03-22 南京理工大学 一种基于tcm的涉密信息移植***
CN105871539A (zh) * 2016-03-18 2016-08-17 华为技术有限公司 一种密钥处理方法及装置
CN106096446A (zh) * 2016-06-15 2016-11-09 北京工业大学 一种可信计算环境中密码服务接口的封装方法
CN106096446B (zh) * 2016-06-15 2019-01-15 北京工业大学 一种可信计算环境中密码服务接口的封装方法
CN106775656A (zh) * 2016-11-28 2017-05-31 江西金格科技股份有限公司 一种基于多智能密钥盘的调度方法
CN106775656B (zh) * 2016-11-28 2020-03-31 江西金格科技股份有限公司 一种基于多智能密钥盘的调度方法
CN114385248A (zh) * 2020-10-22 2022-04-22 四零四科技股份有限公司 处理信任链的计算***及装置
CN114385248B (zh) * 2020-10-22 2024-04-23 四零四科技股份有限公司 处理信任链的计算***及装置

Also Published As

Publication number Publication date
CN102842005B (zh) 2015-06-10

Similar Documents

Publication Publication Date Title
CN102842005B (zh) 一种基于tsm的tspi接口的csp模块和csp实现方法
CN102646077B (zh) 一种基于可信密码模块的全盘加密的方法
US9251380B1 (en) Method and storage device for isolating and preventing access to processor and memory used in decryption of text
CN103221961B (zh) 包括用于保护多用户敏感代码和数据的架构的方法和装置
US9824239B2 (en) System for and method of cryptographic provisioning
KR101712784B1 (ko) 글로벌 플랫폼 규격을 사용하는 발행자 보안 도메인에 대한 키 관리 시스템 및 방법
CN100354786C (zh) 开放型通用抗攻击cpu及其应用***
CN103457739B (zh) 一种动态令牌参数获取方法与设备
CN103902915B (zh) 一种可信工控终端及其构建方法
CN114465726B (zh) 基于安全单元和可信执行环境的数字钱包安全框架***
CN104021335B (zh) 基于可扩展密码服务框架的密码服务方法
CN116601912A (zh) 提供加密安全的后秘密供应服务
CN103457742A (zh) 一种基于usb key的安全套件库***
CN111783078A (zh) Android平台安全芯片控制***
CN103971034A (zh) 一种保护Java软件的方法及装置
CN109478214A (zh) 用于证书注册的装置和方法
WO2023240866A1 (zh) 密码卡及其根密钥保护方法、计算机可读存储介质
CN104715208A (zh) 一种基于tpm芯片的平台完整性校验方法
CN100596058C (zh) 可信计算平台密钥授权数据管理***及方法
CN114050915A (zh) 隔离网络下细粒度权限访问同步方法、装置及设备
EP4205347A1 (en) Data management and encryption in a distributed computing system
CN116886356B (zh) 一种芯片级透明文件加密存储***、方法及设备
EP2232760A1 (en) System for and method of cryptographic provisioning
CN104899480A (zh) 一种基于cpk标识认证技术的软件版权保护管理方法
CN113676446B (zh) 通信网络安全防误控制方法、***、电子设备及介质

Legal Events

Date Code Title Description
C06 Publication
PB01 Publication
C10 Entry into substantive examination
SE01 Entry into force of request for substantive examination
C14 Grant of patent or utility model
GR01 Patent grant