Python gmssl.SM4使用案例

Python gmssl.SM4使用案例

       摘要:在異構計算系統驗證中,通常會有數據加解密的要求,例如用戶數據、權重參數等,本文將詳細介紹在UVM驗證環境中,調用Python的gmssl庫,用SM4實現加解密的驗證方案。

一、Python gmssl 庫介紹

       gmssl 是一個開源的、純Python實現的國密算法庫。它的最大特點是不依賴任何底層C庫(如OpenSSL),這使得它在各種環境中部署和使用都非常方便,尤其適合作為算法行為級參考模型(Golden Model/Oracle)。

1.1 主要功能和支持的算法:

  1. SM2 (非對稱加密和簽名): 基于橢圓曲線的公鑰密碼算法,用于加密通信、數字簽名和密鑰交換。
  2. SM3 (哈希算法): 密碼雜湊算法,輸出256位的哈希值,功能類似于SHA-256。
  3. SM4 (對稱加密): 分組密碼算法,分組長度和密鑰長度都是128位,用于數據加密,功能類似于AES-128。
  4. ZUC (祖沖之序列密碼): 用于移動通信4G/5G網絡的對稱加密和完整性保護。

1.2 為什么在驗證中選擇 gmssl

  • 純Python實現:易于安裝和部署,pip install gmssl 即可,避免了復雜的編譯和環境依賴問題。
  • 代碼可讀性高:可以直接閱讀其Python源碼來理解算法標準,非常適合作為學習和開發的參考。
  • 易于集成:可以非常方便地與UVM驗證環境通過DPI-C進行橋接,構建強大的參考模型。

二、gmssl 庫用法示例

首先,安裝gmssl庫:

pip install gmssl

1. SM4 對稱加密示例 (最常用于RTL驗證)

       SM4是分組密碼,處理數據時需要指定模式(Mode)填充(Padding)。這里以常用的CBC (Cipher Block Chaining)模式為例。

# sm4_example.py
from gmssl.sm4 import Sm4, SM4_ENCRYPT, SM4_DECRYPT# 密鑰和初始化向量(IV)都必須是128位 (16字節)
key = b'\x01\x23\x45\x67\x89\xab\xcd\xef\xfe\xdc\xba\x98\x76\x54\x32\x10'
iv = b'\x01\x23\x45\x67\x89\xab\xcd\xef\xfe\xdc\xba\x98\x76\x54\x32\x10'# 待加密的明文,這里是128位 (16字節)
# 在RTL驗證中,我們通常處理一個或多個完整的數據塊,可以不使用padding
plaintext = b'\x01\x23\x45\x67\x89\xab\xcd\xef\xfe\xdc\xba\x98\x76\x54\x32\x10'# 1. 初始化SM4加密器
crypt_sm4 = Sm4()
crypt_sm4.set_key(key, SM4_ENCRYPT) # 設置為加密模式# 2. 加密
# 使用CBC模式進行加密,輸入為bytes,輸出也為bytes
ciphertext = crypt_sm4.crypt_cbc(iv, plaintext)print("--- SM4 CBC Mode ---")
print(f"Key        : {key.hex()}")
print(f"IV         : {iv.hex()}")
print(f"Plaintext  : {plaintext.hex()}")
print(f"Ciphertext : {ciphertext.hex()}")# 3. 解密過程
crypt_sm4.set_key(key, SM4_DECRYPT) # 切換為解密模式
decrypted_text = crypt_sm4.crypt_cbc(iv, ciphertext)print(f"Decrypted  : {decrypted_text.hex()}")# 4. 驗證結果
assert decrypted_text == plaintext
print("\nEncryption and Decryption successful!")

2. SM3 哈希算法示例

# sm3_example.py
from gmssl.sm3 import sm3_hash# 待計算哈希的數據 (bytes)
data_to_hash = b'hello world'# 計算哈希值,輸入為bytes,輸出也為bytes (32字節, 256位)
hash_value = sm3_hash(list(data_to_hash)) # gmssl的sm3_hash接收一個byte列表print("--- SM3 Hash ---")
print(f"Data       : {data_to_hash.decode()}")
print(f"Hash Value : {hash_value.hex()}") # 以十六進制字符串輸出

3. SM2 非對稱加密示例

# sm2_example.py
from gmssl.sm2 import sm2_crypt# 1. 生成SM2密鑰對 (公鑰和私鑰)
sm2_key = sm2_crypt.gen_key()
private_key = sm2_key.private_key.hex()
public_key = sm2_key.public_key.hex()print("--- SM2 Asymmetric Encryption ---")
print(f"Private Key: {private_key}")
print(f"Public Key : {public_key}")# 2. 使用公鑰加密
data_to_encrypt = b'this is a secret message'
encryptor = sm2_crypt.Sm2Crypt(public_key=public_key)
ciphertext = encryptor.encrypt(data_to_encrypt)print(f"\nPlaintext  : {data_to_encrypt.decode()}")
print(f"Ciphertext : {ciphertext.hex()}")# 3. 使用私鑰解密
decryptor = sm2_crypt.Sm2Crypt(private_key=private_key)
decrypted_text = decryptor.decrypt(ciphertext)print(f"Decrypted  : {decrypted_text.decode()}")assert decrypted_text == data_to_encrypt
print("\nSM2 Encryption and Decryption successful!")

三、gmssl 數據與 SystemVerilog 驗證環境交互

       在UVM等SystemVerilog驗證環境中,與Python腳本交互的最佳實踐是通過DPI-C接口。這形成了一個穩定且高效的三層架構:UVM <-> C <-> Python。下面以SM4加密為例,展示一個完整的交互流程。

步驟 1: 創建Python腳本作為Oracle (gmssl_oracle.py)

這個腳本通過命令行接收指令和數據,并從標準輸出返回結果。這是解耦的關鍵。

# gmssl_oracle.py
import sys
from gmssl.sm4 import Sm4, SM4_ENCRYPT, SM4_DECRYPTdef main():# 命令行參數: gmssl_oracle.py <encrypt|decrypt> <key_hex> <iv_hex> <data_hex>if len(sys.argv) != 5:print("Error: Invalid arguments.", file=sys.stderr)sys.exit(1)mode, key_hex, iv_hex, data_hex = sys.argv[1:]try:key = bytes.fromhex(key_hex)iv = bytes.fromhex(iv_hex)data = bytes.fromhex(data_hex)except ValueError as e:print(f"Error: Invalid hex string. {e}&

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/913196.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/913196.shtml
英文地址,請注明出處:http://en.pswp.cn/news/913196.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

迅為高情性6TOPS算力的RK3576開發板NPU rknn-model-zoo例程演示

迅為iTOP-3576開發板采用瑞芯微RK3576高性能、低功耗的應用處理芯片&#xff0c;集成了4個Cortex-A72和4個Cortex-A53核心&#xff0c;以及獨立的NEON協處理器。它適用于ARM PC、邊緣計算、個人移動互聯網設備及其他多媒體產品。支持INT4/INT8/INT16/FP16/BF16/TF32混合運算&am…

rsync 命令詳解

目錄 rsync 傳輸備份工作原理詳解一、核心算法:差異傳輸二、傳輸流程三、關鍵技術四、與cp/scp復制的本質區別rsync的使用基本語法常用選項常用組合案例1. **本地目錄同步**2. **遠程同步(SSH協議)**3. **刪除目標端多余文件**4. **排除特定文件**5. **限速傳輸(避免占用帶…

【MySQL進階】錯誤日志,二進制日志,mysql系統庫

目錄 一.錯誤日志 1.1 配置錯誤日志 1.1.1 Windows的默認錯誤日志路徑 1.1.2 Unix和Linux系統的默認錯誤日志路徑 1.2 錯誤日志中事件的字段 1.2.1 核心錯誤事件字段 1.2.2.MySQL 錯誤消息的兩種不同輸出渠道 1.2.3 可選錯誤事件字段 1.3. 刷新錯誤日志文件和重命名 二…

day45-nginx復雜跳轉與https

1. ?nginx復雜跳轉 客戶端ip不是內網(172.16/192.168)ip時&#xff0c;維護文件存在時&#xff0c;返回503或者錯誤頁面 1.1. &#x1f4dd;修改配置文件 server {listen 80;server_name re.linux.cn; root /app/code/re/;set $flag 0;if ( $remote_addr !~* "^172…

基于pcl點云庫實現激光雷達數據采集

基于pcl點云庫實現倍加福R2000激光雷達數據采集 一、項目介紹二、開發詳情三、顯示效果展示四、說明 一、項目介紹 最近用pcl庫實現了倍加福R2000激光雷達的數據采集&#xff0c;并實時在viewer上實時更新顯示。軟件的開發是基于vs2019qt插件pcl庫實現&#xff0c;可以完成如下…

微信小程序61~70

1.組件wxml的slot-插槽 在使用基礎組件時&#xff0c;可以在組件中間寫子節點&#xff0c;從而將子節點內容展示到頁面中&#xff0c;自定義組件也可以接收子節點但是要在組件模板中定義節點&#xff0c;承載組件中間的子節點需要使用多個插槽時&#xff0c;要在組件.js中聲明…

03_性能優化:讓軟件呼吸更順暢

引言 在用戶對軟件響應速度近乎苛刻的今天&#xff0c;性能已成為產品競爭力的核心指標。據Google研究&#xff0c;頁面加載時間每增加1秒&#xff0c;轉化率就會下降20%。本文將從前端、后端、移動端三個維度&#xff0c;揭示性能優化的核心策略與實戰技巧&#xff0c;幫助你打…

LangChain4j 框架模仿豆包實現智能對話系統:架構與功能詳解

系統整體架構設計基于 LangChain4j 框架構建的智能對話系統采用 "前后端分離 大模型中樞" 的三層架構設計&#xff0c;實現了與豆包類似的智能交互體驗。系統架構圖如下所示&#xff1a;┌────────────────────────────────────…

基于uni-app的書法學習管理小程序的設計與實現

一、設計的目的 書法是中華民族傳統文化的瑰寶&#xff0c;更是人類文明的寶貴財富&#xff0c;具有深遠的意義和實價值。在當今數字化時代&#xff0c;隨著信息技術的飛速發展&#xff0c;傳統書法學習模式面臨著諸多挑戰和需要解決的問題。為推動書法學習的現代化轉型&#…

NumPy 函數庫在數學建模中的基本使用方法

一、引言 在數學建模的世界里,我們常常需要處理大量的數據和進行復雜的數值計算。Python 中的 NumPy 庫就像是一位得力的助手,它為我們提供了強大的多維數組對象和豐富的數學函數,讓我們能夠高效地完成各種數值計算任務。接下來,我們將深入探討 NumPy 在數學建模中的基本使…

模塊三:現代C++工程實踐(4篇)第一篇《C++模塊化開發:從Header-only到CMake模塊化》

引言&#xff1a;現代C工程化的核心挑戰&#xff08;終極擴展版&#xff09; 在云計算與物聯網時代&#xff0c;C項目規模呈指數級增長。傳統Header-only開發模式暴露出編譯效率低下、依賴管理混亂、版本沖突頻發等致命問題。本文通過CMake 3.22Conan 2.0工具鏈的深度集成&…

uniapp啟動圖被拉伸問題

記錄下&#xff1a; 安卓手機有不同的規格&#xff0c;很難所有規格都去適配。如果不適配所有機型&#xff0c;那么就會導致部分機型的啟動圖被拉伸。 安卓提供了.9.png圖片格式&#xff0c;允許標注部分拉伸&#xff0c;這樣啟動圖中間的logo就不會被拉伸。 下面2張圖是沒有…

stm32的三種開發方式

以下是針對STM32F103RC實現LED閃爍&#xff08;PC13引腳&#xff09;的三種開發方式示例代碼&#xff0c;每種方式均保持相同的核心邏輯&#xff1a; 1. 寄存器開發方式&#xff08;直接操作寄存器&#xff09; #include "stm32f10x.h"int main(void) {// 1. 開啟G…

SpringBoot問卷調查系統設計與實現

概述 基于SpringBoot開發的問卷調查系統&#xff0c;該系統集成了問卷管理、題目管理等多種功能模塊。 主要內容 核心功能模塊&#xff1a; ??個人信息管理??&#xff1a; 修改密碼個人信息修改 ??問卷管理??&#xff1a; 問卷新增問卷修改問卷刪除 ??題目管理?…

Linux進程管理:從基礎到實戰

在 Linux 系統編程中&#xff0c;進程&#xff08;Process&#xff09; 是操作系統進行資源分配和調度的基本單位。理解進程的概念是掌握系統編程、多任務處理、并發編程的基礎。 目錄 一、什么是進程&#xff1f; 定義&#xff1a; 二、進程的生命周期 示例&#xff1a;查…

工業物聯網中的 Modbus:傳感器與網關通信實戰(二)

四、實戰案例解析 4.1 項目背景與目標 某智能工廠致力于提升生產過程的自動化和智能化水平&#xff0c;對生產線上的各種設備進行實時監控和數據分析。在該工廠的一個生產車間中&#xff0c;存在著大量的傳感器&#xff0c;用于監測設備的運行狀態、環境參數等信息。這些傳感…

飛算 JavaAI 智控引擎:全鏈路開發自動化新圖景

免責聲明: 此文章的所有內容皆是本人實驗測評&#xff0c;并非廣告推廣&#xff0c;并非抄襲。如有侵權&#xff0c;請聯系&#xff0c;謝謝! 文章目錄&#x1f4dd;前言一、飛算 Java AI 智能開發助手簡介1.1何為飛算 Java AI智能助手&#xff1f;2.2 飛算Java AI 直擊開發全場…

MYSQL數據庫(九)MVCC-多版本并發控制

目錄 一 前景導入 1 當前讀 2 快照讀 二 MVCC 1 隱藏字段 2 UndoLog 回滾日志 (1 UndoLog日志 (2 UndoLog版本鏈 3 Read View 面試八股 介紹一下MVCC 一 前景導入 1 當前讀 可使當前事務讀取的是最新版本的數據&#xff0c;讀取時還要保證其他并發事務不能修改當中…

[Pytest] [Part 2]增加 log功能

開始實現需求之前先做個log類&#xff0c;可以給其他模塊使用&#xff0c;也方便以后修改log類的功能和屬性。 使用的是python中的logging包來進行簡單的封裝&#xff0c;具體代碼如下 import logging import sysclass TefLogger:def __init__(self, logger_nameTEST_FRAMEWOR…

NeighborGeo:基于鄰居的IP地理定位(三)

NeighborGeo:基于neighbors的IP地理定位 X. Wang, D. Zhao, X. Liu, Z. Zhang, T. Zhao, NeighborGeo: IP geolocation based on neighbors, Comput. Netw. 257 (2025) 110896, 3. NeighborGeo 本文提出NeighborGeo,利用圖結構學習和有監督對比學習來建立可靠的地標-目標關…