CSP国密算法研究之西电捷通HUFU Cipher Service Provider

本文介绍了西电捷通的HUFU Cipher Service Provider技术,按照CryptoAPI2.0标准实现国密算法SM2、SM3、SM4等,无需依赖硬件,提供数字签名、密钥协商、加密解密等功能。通过创建动态链接库、资源文件签名等步骤,可以将HUFU CSP集成到Windows系统,应用于各种网络安全和加密场景。


(西电捷通架构与编码研究)



导读:作为 Microsoft Windows 的组成部分,CryptoAPI是提供应用程序编程接口(API)的规范,由它提供的一组函数接口允许应用程序在对用户的敏感私钥数据提供保护时,以灵活的方式对数据进行加密或数字签名,而实际的加密操作是由称为密码服务提供者(CSPCryptographic Service Provider)的独立模块执行的。国内一些密码产品已经在windows系统中使用,但所使用的SM2SM3SM4ECDSAECDHSHA256等算法均按照各自接口实现,未依据CryptoAPI2.0的标准接口规范, 给应用带来不便。CryptoAPI2.0 CryptoAPI的最新接口,它是在1.0的基础上添加了对证书管理的支持。


随着国产密码算法的不断涌现,许多公司也提供了CSP相关国密算法的支持,但大部分CSP实现的内容仅是一个空框架,其密码算法的实现是通过调用相关的硬件,如USBKeySDKey和密码板卡等,并未真正实现密码算法。在实际应用中,确实存在因用户不想插接硬件而增加成本,或硬件设备没有对应的物理接口,这时可能有些用户会在应用层自己实现密码算法或干脆不用密码算法,导致安全性大大降低。那么有没有采用CSP架构,且不用硬件的国密算法呢?答案是有,由西电捷通研发的HUFU CipherService Provider技术就是一种基于CSP机制对国密算法的实现。


 


一、HUFU

Android SM2、SM3、SM4 算法支持 Service Provider 及证书制作软件包 算法 JCAJCE Service Provider,适应版本 Android 4.2.2~7.0 支持 SM2 的 KeyFactory、KeyPairGenerator、Cipher、Signature、X.509 CertificateFactory 接口 支持 SM3 的 MessageDigest 接口、SM3withSM2 混合算法 支持 SM4 的 Cipher、KeyFactory、KeyGenerator、SecretKey 接口、相关算法 CMAC-SM4、Poly1305-SM4 增加 java.security.PublicKey 的子类 SM2PublicKey 增加 java.security.PrivateKey 的子类 SM2PrivateKey 全功能支持 SM3withSM2 算法的 X.509 证书结构体解释与码运算 支持 BKS、PKCS#12 KeyStore 生成、解释、验算 X.509v1/v3 证书,签名算法支持 SM3withSM2、主流 RSA、DSA、ECDSA.... 生成、解释、验算 PKCS#10 证书申请,签名算法支持 SM3withSM2、主流 RSA、DSA、ECDSA.... *** 无须打包 BouncyCastle 支持库,体积小、节约内存 *** 请参阅 testSM.java、testCERT.java 文件列表: 1、AndroidSM.jar -- SM2、SM3、SM4 算法/证书支持的 JCA/JCE Service Provider 类库 2、AndroidCRT.jar -- X.509 数字证书/PKCS#10 证书申请相关类库 3、bc422.jar -- BouncyCastle 加库,Android 4.2.2 内置版本(由真机导出dex文件转换而得,仅用于编译时选用,勿打包到apk文件中) 4、testSM.java -- SM2、SM3、SM4 算法相关类引用范例 5、testCERT.java -- X.509 数字证书/PKCS#10 证书申请相关类引用范例 6、readme.txt -- 本文 因条件及精力限制,各类、方法的实现未经严格彻底的测试,不宜用于商业用途软件的开发。 如欲将本开发包发布、上传、拷贝、共享等,务必保持其内容完整性(包括本文) 如有需要帮助或者索取源码,请联系 suntongo@qq.com, suntongo@hotmail.com
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值