GM/T 0018-2012 设备接口描述笔记

GM/T 0018-2012 设备接口描述笔记

文章目录

  • GM/T 0018-2012 设备接口描述笔记
    • 6. 设备接口描述
      • 6.1 密码设备应用接口在公钥密码基础设施应用技术体系框架中的位置
      • 6.2 设备管理类函数
      • 6.3 密钥管理类函数
      • 6.4 非对称算法运算类函数
      • 6.5 对称算法运算类函数
      • 6.6 杂凑运算类函数
      • 6.7 用户文件操作类函数

6. 设备接口描述

6.1 密码设备应用接口在公钥密码基础设施应用技术体系框架中的位置

在公钥密码基础设施应用技术体系框架中,密码设备服务层由密码机、密码卡、智能密码终端等设备组成,通过本标准规定的密码设备应用接口向通用密码服务层提供基础密码服务。如图1所示。
基础密码服务包括密钥生成、单一的密码运算、文件管理等的服务。
本标准采用 C语言描述接口函数。如无特别说明,函数中参数的长度单位均为字节数。
[图片]

6.2 设备管理类函数

设备管理类函数包括以下具体函数,各函数返回值见附录A函数返回代码定义:

  • 打开设备: SDF_OpenDevice
  • 关闭设备: SDF_CloseDevice
  • 创建会话: SDF_OpenSession
  • 关闭会话: SDF_CloseSession
  • 获取设备信息: SDF_GetDeviceInfo
  • 产生随机数: SDF_GenerateRanDom
  • 获取私钥使用权限: SDF_GetPrivateKeyAccessRight
  • 释放私钥使用权限: SDF_ReleasePrivateKeyAccessRight

6.3 密钥管理类函数

密钥管理类函数包括以下具体函数,各函数返回值见附录A函数返回代码定义:

  • 导出 RSA 签名公钥: SDF_ExportSignPublicKey_RSA

  • 导出 RSA 加密公钥: SDF_ExportEncPublicKey_RSA

  • 产生 RSA 非对称密钥对并输出: SDF_GenerateKeyPair_RSA

  • 生成会话密钥并用内部 RSA 公钥加密输出: SDF_GenerateKeyWithIPK_RSA

  • 生成会话密钥并用外部 RSA 公钥加密输出: SDF_GenerateKeyWithEPK_RSA

  • 导入会话密钥并用内部 RSA 私钥解密: SDF_ImportKeyWithISK_RSA

  • 基于 RSA 算法的数字信封转换: SDF_ExchangeDigitEnvelopeBaseOnRSA

  • 导出ECC签名公钥: SDF_ExportSignPublicKey_ECC

  • 导出ECC加密公钥: SDF_ExportEncPublicKey_ECC

  • 产生ECC非对称密钥对并输出: SDF_GenerateKeyPair_ECC

  • 生成会话密钥并用内部ECC公钥加密输出: SDF_GenerateKeyWithIPK_ECC

  • 生成会话密钥并用外部ECC公钥加密输出: SDF_GenerateKeyWithEPK_ECC

  • 导入会话密钥并用内部ECC私钥解密: SDF_ImportKeyWithISK_ECC

  • 生成密钥协商参数并输出: SDF_GenerateAgreementDataWithECC

  • 计算会话密钥: SDF_GenerateKeyWithECC

  • 产生协商数据并计算会话密钥: SDF_GenerateAgreementDataAndKeyWithECC

  • 基于ECC算法的数字信封转换: SDF_ExchangeDigitEnvelopeBaseOnECC

  • 生成会话密钥并用密钥加密密钥加密输出: SDF_GenerateKeyWithKEK

  • 导入会话密钥并用密钥加密密钥解密: SDF_ImportKeyWithKEK

  • 导入明文会话密钥: SDF_ImportKey (GMSSL中没有)

  • 销毁会话密钥: SDF_DestroyKey

6.4 非对称算法运算类函数

非对称算法运算类函数包括以下具体函数,各函数返回值见附录A函数返回代码定义:

  • 外部公钥RSA运算: SDF_ExternalPublicKeyOperation_RSA

  • 外部私钥RSA运算: SDF_ExternalPrivateKeyOperation_RSA (GMSSL中没有)

  • 内部公钥RSA运算: SDF_InternalPublicKeyOperation_RSA

  • 内部私RSA运算: SDF_InternalPrivateKeyOperation_RSA

  • 外部密钥ECC签名: SDF_ExternalSign_ECC (GMSSL中没有)

  • 外部密钥ECC验证: SDF_ExternalVerify_ECC

  • 内部密钥ECC签名: SDF_InternalSign_ECC

  • 内部密钥ECC验证: SDF_InternalVerify_ECC

  • 外部密钥ECC加密: SDF_ExternalEncrypt_ECC

  • 内部密钥ECC加密: SDF_InternalEncrypt_ECC (标准中没有)

  • 内部密钥ECC解密: SDF_InternalDecrypt_ECC (标准中没有)

  • 外部密钥ECC解密: SDF_ExternalDecrypt_ECC (GMSSL中没有)

6.5 对称算法运算类函数

对称算法运算类函数包括以下具体函数,各函数返回值见附录A函数返回代码定义:

  • 对称加密: SDF_Encrypt
  • 对称解密: SDF_Decrypt
  • 计算MAC: SDF_CalculateMAC

6.6 杂凑运算类函数

杂凑运算类函数包括以下具体函数,各函数返回值见附录A函数返回代码定义:

  • 杂凑运算初始化: SDF_HashInit
  • 多包杂凑运算: SDF_HashUpdate
  • 杂凑运算结束: SDF_HashFinal

6.7 用户文件操作类函数

用户文件操作类函数包括以下具体函数,各函数返回值见附录A函数返回代码定义:

  • 创建文件: SDF_CreateFile
  • 读取文件: SDF_ReadFile
  • 写文件: SDF_WriteFile
  • 删除文件: SDF_DeleteFile

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/356092.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

单调队列优化DP模型整理

135. 最大子序和(活动 - AcWing) 找一个长度不超过m的连续子序列,但是并未指定这个子序列的长度,所以长度就有很多种选择,要获取任意一段长度的序列的区间和,那么显然要用到前缀和。然后我们来考虑&#xf…

leetcode hot100跳跃游戏

在本题中,我们要模仿整个跳跃过程,当前位置数组元素为nums[i],那我们就最大能往后跳nums[i]步,可以小于等于这个数。如果我们直接遍历数组,那么我们需要每一步都控制跳跃0——nums[i]步,这样不可能实现。 …

ITSS证书:点亮职业发展的明灯

📚ITSS是中国电子技术标准化研究院推出的权威认证,涵盖IT服务工程师和IT服务经理的系列培训,旨在培养具备专业知识和技能的IT服务人才。 🌟证书优势: 1️⃣提升问题解决能力:通过学习ITSS方法论和实践经验&…

【网络】WireShark过滤 | WireShark实现TCP三次握手和四次挥手

目录 一、开启WireShark的大门 1.1 WireShark简介 1.2 常用的Wireshark过滤方式 二、如何抓包搜索关键字 2.1 协议过滤 2.2 IP过滤 ​编辑 2.3 过滤端口 2.4 过滤MAC地址 2.5 过滤包长度 2.6 HTTP模式过滤 三、ARP协议分析 四、WireShark之ICMP协议 五、TCP三次握…

Python笔记15-实战小游戏飞机大战(中)

文章目录 创建第一个敌机创建一群敌机创建多行敌机让敌机移动射杀敌机生成新的敌机群结束游戏有敌机到达屏幕底端游戏结束 在上一篇基础上继续 本示例源码地址 点击下载 创建第一个敌机 在屏幕上放置外星人与放置飞船类似。每个外星人的行为都由Alien 类控制,我们…

C++面试宝典第25题:阶乘末尾零的个数

题目 给定一个整数n,返回n!(n的阶乘)结果尾数中零的个数。 示例 1: 输入:3 输出:0 解释:3! = 6,尾数中没有零。 示例 2: 输入:5 输出:1 解释:5! = 120,尾数中有1个零。 解析 这道题主要考察应聘者对于数学问题的分析和理解能力,以及在多个解决方案中,寻求最优…

从零学习Linux操作系统 第二十部分 mariadb数据库的管理

一、对于数据库的基本介绍 1.什么是数据库 数据库就是个高级的表格软件 2.常见数据库 Mysql Oracle mongodb db2 sqlite sqlserver … 3.Mysql (SUN -----> Oracle) 4.mariadb (Mysql的一种) 数据库中的常用名词 1.字段 :表格中的表头 2.表 &…

MySQL原理(一)架构组成(1)物理文件组成

目录 一、日志文件 1、错误日志 Error Log 1.1、作用: 1.2、开启关闭: 1.3、使用 2、二进制日志 Binary Log & Binary Log Index 2.1、作用: 2.2、开启关闭: 2.3、Binlog还有一些附加选项参数 (1&#x…

嵌入式C++必知必会之基础知识-常用关键字(1)

温故而知新 Hello,大家好!我是木荣。温故而知新,可以为师矣。作为一名攻城狮,扎实的基本功是解决问题及完成工作中任务的重要前提。没有良好的基本功作为铺垫,一味的追求知识的宽度是毫无意义,知其然更要知…

野火霸道V2学习笔记

STM32F103学习笔记 STM32F103学习笔记说明基础配置配置KeilMDK配置串口下载程序美化Keil界面配置VScode 理论知识STM32命名方式例子 置位与清零GPIOGPIO简介GPIO和引脚的区别引脚的分类 GPIO 框图讲解保护二极管推挽输出推挽输出的含义推挽输出的原理推挽输出的特点推挽输出的应…

力扣题目训练(3)

2024年1月27日力扣题目训练 2024年1月27日力扣题目训练290. 单词规律292. Nim 游戏303. 区域和检索 - 数组不可变91. 解码方法92. 反转链表 II41. 缺失的第一个正数 2024年1月27日力扣题目训练 2024年1月27日第三天编程训练,今天主要是进行一些题训练,包…

大数据Doris(六十一):SQL函数之Bitmap函数

文章目录 SQL函数之Bitmap函数 一、BITMAP_AND(BITMAP lhs, BITMAP rhs)

用C#实现最小二乘法(用OxyPlot绘图)

最小二乘法介绍✨ 最小二乘法(Least Squares Method)是一种常见的数学优化技术,广泛应用于数据拟合、回归分析和参数估计等领域。其目标是通过最小化残差平方和来找到一组参数,使得模型预测值与观测值之间的差异最小化。 最小二…

小白都会的幻兽帕鲁服务器搭建教程(详细图文)

​  简介:由于幻兽帕鲁游戏的火爆,导致其官方服务器频现游戏卡顿掉线,为了能够正常流畅的体验幻兽帕鲁,有不少人都搭建了幻兽帕鲁服务器(私服),网上虽然也有很多幻兽帕鲁服务器搭建教程,但内容专业性有点…

qq通讯录怎么关闭?QQ好友删除了怎么恢复?

在QQ中,通讯录是我们管理好友和进行聊天的重要工具,但有时候我们可能需要一些隐私保护,不让一些用户通过手机通讯录添加自己。如果您正在思考qq通讯录怎么关闭以及恢复意外删除的好友,本文将为您详细介绍如何关闭QQ通讯录和恢复被…

Java开发秘籍:实战公众号开发指南

目录 第一章:公众号开发简介 1.1 什么是公众号开发 1.2 公众号开发的意义和应用场景 1.3 公众号开发的技术要求和基础知识 第二章:搭建公众号开发环境 2.1 配置Java开发环境 2.2 下载和安装开发工具 2.3 设置公众号开发所需的配置文件 第三章&a…

2024阿里云和腾讯云的第一战打响:搭建《幻兽帕鲁》私服游戏

为了搭建《幻兽帕鲁》游戏私服, 2024年阿里云 VS 腾讯云的第一场战争开始了…… 事情是这样的: 1月19日,最离谱新游 《幻兽帕鲁》突然爆火了,这是一款日本开发商展耗费4年开发的冒险类游戏,这款戏一推出就迅速俘获了…

优思学院|精益管理如何判定哪些活动是增值或非增值?

“时间就是金钱”——这句老话我们都耳熟能详。但在工作中,我们真正从事的、对组织增加价值的活动有多少呢?我们常常认为自己的每一项任务都是维持运营的关键。然而,当我们从精益管理的视角进行分析,可能会惊讶地发现,…

蓝牙----蓝牙连接建立_连接建立

蓝牙----蓝牙连接建立_连接建立 蓝牙连接建立过程图1.主机扫描到广播包1.1判断是否是自己关心的广播包1.2广播地址添加到扫描列表 2.主机扫描结束,建立连接3.主从连接成功后,执行连接建立后事件3.1.主机将连接句柄和设备地址添加到连接列表3.2.主机进行G…

spring boot学习第八篇:操作elastic search的索引和索引中的数据

前提参考&#xff1a;elastic search入门-CSDN博客 前提说明&#xff1a;已经安装好了elastic search 7.x版本&#xff0c;我的es版本是7.11.1 1、 pom.xml文件内容如下&#xff1a; <?xml version"1.0" encoding"UTF-8"?> <project xmlns&q…