PKCS11接口解析「建议收藏」

PKCS11接口解析「建议收藏」pkcs密码中间件位于上层应用和底层安全设备之间,应用基于PKCS#11标准接口开发各类应用程序。主要包括2个库主API库:提供给应用的PKCS11接口。 tokenDLL库:由主API库调用,完成从上向下到指定设备的套接。 安全密码设备:安全服务资源和实施的载体,完成具体安全功能支撑。表pkcs11函数接口 种类 函数 …

大家好,又见面了,我是你们的朋友全栈君。

pkcs密码中间件位于上层应用和底层安全设备之间,应用基于 PKCS#11 标准接口开发各类应用程序。主要包括2个库

  • 主API库:    提供给应用的PKCS11接口。
  • tokenDLL库:由主 API 库调用,完成从上向下到指定设备的套接。
  • 安全密码设备:安全服务资源和实施的载体,完成具体安全功能支撑。

表 pkcs11函数接口

种类

函数

描述

通用l

C_Initialize

初始化 Cryptoki

目的函数

C_Finalize

清除各种Cryptoki相关资源

 

C_GetInfo

获得关于Cryptoki的通用信息

 

C_GetFunctionList

获得Cryptoki 库函数的进入点

槽和令牌

C_GetSlotList

获得系统中槽的名单

管理

C_GetSlotInfo

获得关于特殊槽的信息

函数

C_GetTokenInfo

获得关于特殊令牌的信息

 

C_WaitForSlotEvent

等待槽事件(令牌插入,转移等) 的发生

 

C_GetMechanismList

获得由令牌支持的机制的名单

 

C_GetMechanismInfo

获得关于特殊机制的信息

 

C_InitToken

初始化一个令牌

 

C_InitPIN

初始化普通用户的 PIN

 

C_SetPIN

改变现在用户的PIN

会话管理函数

C_OpenSession

打开一个应用程序和特殊令牌之间的连接或安装一个应用程序呼叫返回令牌插入

 

C_CloseSession

关闭一个会话

 

C_CloseAllSessions

用令牌关闭所有的会话

 

C_GetSessionInfo

获得关于会话的信息

 

C_GetOperationState

获得会话的加密操作状态

 

C_SetOperationState

设置会话的加密操作状态

 

C_Login

注册一个令牌

 

C_Logout

从一个令牌注销

对象管理函数

C_CreateObject

建立一个对象

 

C_CopyObject

建立一个对象的拷贝

 

C_DestroyObject

销毁一个对象

 

C_GetObjectSize

获取字节中一个对象的大小

 

C_GetAttributeValue

获取一个对象的属性值

 

C_SetAttributeValue

改变一个对象的属性值

 

C_FindObjectsInit

初始化一个对象的搜索操作

 

C_FindObjects

继续一个对象搜索操作

 

C_FindObjectsFinal

完成一个对象搜索操作

加密

C_EncryptInit

初始化一个加密操作

函数

C_Encrypt

加密单部分数据

 

C_EncryptUpdate

继续一个多部分加密操作

 

C_EncryptFinal

完成一个多部分加密操作

解密

C_DecryptInit

初始化一个解密操作

函数

C_Decrypt

解密单部分加密数据

 

C_DecryptUpdate

继续一个多部分解密操作

 

C_DecryptFinal

完成一个多部分解密操作

消息

C_DigestInit

初始化一个消息摘要操作

解密

C_Digest

摘要单部分数据

函数

C_DigestUpdate

继续一个多部分摘要操作

 

C_DigestKey

摘要一个密钥

 

C_DigestFinal

完成一个多部分摘要操作

签名

C_SignInit

初始化一个签名操作

和MACing

C_Sign

签名单部分数据

函数

C_SignUpdate

继续一个多部分签名操作

 

C_SignFinal

完成一个多部分签名操作

 

C_SignRecoverInit

初始化一个签名操作,在操作中数据能从签名中恢复

 

C_SignRecover

签名单部分数据,在操作中数据能从签名中恢复

鉴定函数

C_VerifyInit

初始化一个鉴定操作

签名

C_Verify

在单部分数据上鉴定一个签名

和 MACs

C_VerifyUpdate

继续一个多部分鉴定操作

 

C_VerifyFinal

完成一个多部分鉴定操作

 

C_VerifyRecoverInit

初始化一个鉴定操作,在操作中数据能从签名中恢复

 

C_VerifyRecover

在单部分数据上鉴定一个签名,在操作中数据能从签名中恢复

双效加密

C_DigestEncryptUpdate

继续类似的多部分摘要和加密操作

函数

C_DecryptDigestUpdate

继续类似的多部分解密和摘要操作

 

C_SignEncryptUpdate

继续类似的多部分签名和加密操作

 

C_DecryptVerifyUpdate

继续类似的多部分解密和鉴定操作

密钥

C_GenerateKey

产生一个保密密钥

管理

C_GenerateKeyPair

产生一个公共/私钥对

函数

C_WrapKey

加密一个密钥

 

C_UnwrapKey

解密一个密钥

 

C_DeriveKey

从基础密钥派生一个密钥

随机数字生成

C_SeedRandom

把一个附加种子材料加入随机数字生成器

函数

C_GenerateRandom

生成随机数据

并行功能管理函数

C_GetFunctionStatus

经常返回 CKR_FUNCTION_NOT_PARALLEL的遗产函数

 

C_CancelFunction

经常返回 CKR_FUNCTION_NOT_PARALLEL的遗产函数

呼叫返回函数

 

Cryptoki中应用程序提供的处理通知的函数

 

 

导入对象

 

 

删除对象

 

 

导出对象

C_Initialize:        初始化所有slot,通过配置文件读取所有的tokendll,并初始化各个token,初始化信息包括填充tokeninfo,slotinfo,flag等,将以上slotData信息添加到SlotTtable数组中,slotID按顺序依次以1,2,3,4….表示。
C_GetSlotList:     获取slot count和count个slotID。
C_OpenSession: 根据输入slotID打开一个会话,并获取各个token的所有对象属性数据;
在打开会话的基础上调用以下接口:
C_CreateObject:创建对象。根据属性模板创建一个秘钥或证书对象,返回对象句柄,该对象被添加到会话的对象列表中;
C_EncryptInit:     加密初始化操作。传入当前会话句柄和秘钥句柄;
C_Encrypt:          传入会话句柄和待加密数据;
C_GenerateKeyPair:传入公钥和私钥模板,返回公私钥句柄;
C_DestroyObject:销毁对象。从会话的对象列表中移除该对象;

C_CloseSession:关闭会话 

C_Finalize:          清除cryptki相关资源,即清除slotTable中特定slotID的slotData数据,和C_Initialize对应。

 

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/141898.html原文链接:https://javaforall.net

(0)
上一篇 2022年5月24日 下午9:00
下一篇 2022年5月24日 下午9:20


相关推荐

  • 设置div半透明

    设置div半透明DIV 半透明实现 使用 CSS 实现 DIV 成半透明效果 CSS 实现层与背景半透明效果 一 DIVCSS 半透明基础介绍 nbsp nbsp nbsp TOP 设置 DIV 半透明 CSS 代码 div filter alpha Opacity 80 moz opacity 0 5 opacity nbsp 0 5 nbsp 说明 1 filter 对 winIE 设置半透明滤镜效果 filter alpha

    2026年3月18日
    2
  • 史上最全的Vue生命周期钩子函数11个

    史上最全的Vue生命周期钩子函数11个什么是生命周期 生命周期 Vue 是一个构造函数 当执行执行这个函数时 相当于初始化 vue 实例 在创建实例过程中 需要设置数据监听 编译模板 将实例挂载到 DOM 上 数据更新能够让 DOM 也更新 在这个初始化 又会不同阶段默认调用一些函数执行 这些函数就是生命周期的钩子函数 什么是生命周期钩子函数 生命周期钩子函数 能够让我们在初始化实例时 添加自己的代码 生命周期的钩子函数中的 this 会默认指向 vue 的实例 什么是钩子函数 beforeCreate 可以

    2026年3月18日
    2
  • layoutSubviews触发问题

    layoutSubviews触发问题layoutSubviews在以下情况下会被调用: 1、init初始化不会触发layoutSubviews 2、addSubview会触发layoutSubviews 3、设置view的Frame会触发layoutSubviews,当然前提是frame的值设置前后发生了变化 4、滚动一个UIScrollView会触发layoutSubviews 5、旋转Screen会触发父UIView上的layo…

    2022年7月25日
    19
  • TCP-三次握手

    TCP-三次握手文章目录三次握手三次握手过程详解三次握手的状态变化面试题:四次挥手三次握手简单示意图:客户端–发送带有SYN标志的数据包–一次握手–服务端服务端–发送带有SYN/ACK标志的数据包–二次握手–客户端客户端–发送带有带有ACK标志的数据包–三次握手–服务端SYN同步序列编号(SynchronizeSequenceNumbers):是TCP/IP建立连接时使用的握手信号。在客户机和服务器之间建立正常的TCP网络连接时,客户机首先发出一个SYN消息,服务器使用SYN

    2022年10月3日
    5
  • MFC 键盘钩子「建议收藏」

    MFC 键盘钩子「建议收藏」一、前言一日,看见我妈正在用电脑练习打字,频频低头看键盘,我想:要是键盘能发音的话,不就可以方便她养成”盲打”的好习惯吗?光想不做可不行,开始行动(您可千万别急着去拿工具箱啊^_^)…按键能发音,其关键就是让程序能够知道当前键盘上是哪个键被按下,并播放相应的声音,自己的程序当然不在话下,那么其它程序当前按下哪个键如何得知呢?利用键盘钩子便可以很好地解决。下载本文的全部源代码大

    2022年6月7日
    57
  • linux生成md5文件_keil5如何生成bin文件

    linux生成md5文件_keil5如何生成bin文件MDK5如何生成bin文件MDK5在生成bin文件时经常会遇到找不到文件路径导致的生成失败,采用下面这条命令可以直接在.axf目录下生成对应的bin文件:再mdk的Target->User下面这条命令:fromelf.exe–bin-o“$L@L.bin”“#L”生成结果:…

    2022年10月20日
    4

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号