基于AnolisOS 8.6安裝GmSSL 3.1.1及easy_gmssl庫測試國密算法

測試環境

Virtual Box,AnolisOS-8.6-x86_64-minimal.iso,4 vCPU, 8G RAM, 60 vDisk。最小化安裝。需聯網。

系統環境

關閉防火墻
systemctl stop firewalld
systemctl disable firewalld
systemctl status firewalld
selinux關閉
cat /etc/selinux/config

安裝Python39

dnf install -y python39 python39-pip

配置國內pip源

mkdir -p ~/.pip
touch ~/.pip/pip.conf
vi ~/.pip/pip.conf

[global]
trusted-host=mirrors.aliyun.com
index-url=http://mirrors.aliyun.com/pypi/simple/

安裝easy_gmssl

安裝依賴
dnf install -y gcc cmake
安裝easy_gmssl庫
pip3 install easy_gmssl

安裝GmSSL 3.1.1

tar -zxvf GmSSL-3.1.1.tar.gz

cd GmSSL-3.1.1
mkdir build
cd build
cmake ..
make
make install

vi /etc/ld.so.conf,添加一行:
/usr/local/lib
加載動態鏈接
ldconfig

驗證版本
gmssl version

生成公鑰和私鑰
gmssl sm2keygen -pass 123456 -out sm2_private.pem -pubout sm2_public.pem

基于easy_gmssl國密算法的加解密驗簽小腳本

from easy_gmssl import EasySM2SignKey, EasySM2VerifyKey, EasySm4CBC, EasySM3Digest
import os
import logging# 配置日志
logging.basicConfig(level=logging.INFO, format='%(asctime)s - %(levelname)s - %(message)s')def sm4_encrypt(key, iv, plaintext):"""使用SM4算法進行加密:param key: 密鑰,長度為16字節:param iv: 初始化向量,長度為16字節:param plaintext: 明文數據:return: 加密后的密文"""sm4 = EasySm4CBC(key, iv, True)ciphertext = sm4.Update(plaintext) + sm4.Finish()return ciphertextdef sm4_decrypt(key, iv, ciphertext):"""使用SM4算法進行解密:param key: 密鑰,長度為16字節:param iv: 初始化向量,長度為16字節:param ciphertext: 密文數據:return: 解密后的明文"""sm4 = EasySm4CBC(key, iv, False)plaintext = sm4.Update(ciphertext) + sm4.Finish()return plaintextdef sm3_hash(data):"""使用SM3算法進行哈希計算:param data: 待哈希的數據:return: 哈希值"""sm3 = EasySM3Digest()sm3.UpdateData(data)hash_value, _, _ = sm3.GetHash()return hash_value.hex()def sm2_sign(private_key_path, password, data):"""使用SM2算法生成數字簽名:param private_key_path: 私鑰文件路徑:param password: 私鑰文件的密碼:param data: 待簽名的數據:return: 數字簽名"""sm2_signer = EasySM2SignKey(pem_private_key_file=private_key_path, password=password)sm2_signer.UpdateData(data)signature = sm2_signer.GetSignValue()return signature.hex()def sm2_verify(public_key_path, data, signature):"""使用SM2算法驗證數字簽名:param public_key_path: 公鑰文件路徑:param data: 待驗證的數據:param signature: 數字簽名:return: 驗證結果,True表示驗證通過,False表示驗證失敗"""sm2_verifier = EasySM2VerifyKey(pem_public_key_file=public_key_path)sm2_verifier.UpdateData(data)return sm2_verifier.VerifySignature(bytes.fromhex(signature))def encrypt_file(input_file_path, output_file_path, key, iv):"""加密文件:param input_file_path: 待加密文件路徑:param output_file_path: 加密后文件輸出路徑:param key: SM4算法密鑰:param iv: SM4算法初始化向量"""with open(input_file_path, 'rb') as f:plaintext = f.read()ciphertext = sm4_encrypt(key, iv, plaintext)with open(output_file_path, 'wb') as f:f.write(ciphertext)logging.info(f"文件加密完成,輸出路徑:{output_file_path}")def decrypt_file(input_file_path, output_file_path, key, iv):"""解密文件:param input_file_path: 待解密文件路徑:param output_file_path: 解密后文件輸出路徑:param key: SM4算法密鑰:param iv: SM4算法初始化向量"""with open(input_file_path, 'rb') as f:ciphertext = f.read()plaintext = sm4_decrypt(key, iv, ciphertext)with open(output_file_path, 'wb') as f:f.write(plaintext)logging.info(f"文件解密完成,輸出路徑:{output_file_path}")def sign_file(private_key_path, password, input_file_path, output_file_path):"""對文件生成數字簽名:param private_key_path: SM2算法私鑰文件路徑:param password: 私鑰文件的密碼:param input_file_path: 待簽名文件路徑:param output_file_path: 數字簽名輸出路徑"""with open(input_file_path, 'rb') as f:data = f.read()sign = sm2_sign(private_key_path, password, data)with open(output_file_path, 'w') as f:f.write(sign)logging.info(f"數字簽名生成完成,輸出路徑:{output_file_path}")def verify_file_signature(public_key_path, input_file_path, sign_file_path):"""驗證文件的數字簽名:param public_key_path: SM2算法公鑰文件路徑:param input_file_path: 待驗證文件路徑:param sign_file_path: 數字簽名文件路徑:return: 驗證結果"""with open(input_file_path, 'rb') as f:data = f.read()with open(sign_file_path, 'r') as f:sign = f.read()result = sm2_verify(public_key_path, data, sign)return resultdef check_file_integrity(input_file_path):"""檢查文件的完整性:param input_file_path: 待檢查文件路徑:return: 文件的SM3哈希值"""with open(input_file_path, 'rb') as f:data = f.read()hash_value = sm3_hash(data)return hash_valueif __name__ == "__main__":# 示例使用input_file_path = 'example.txt'  # 待處理文件路徑encrypted_file_path = 'encrypted_example.enc'  # 加密后文件路徑decrypted_file_path = 'decrypted_example.txt'  # 解密后文件路徑sign_file_path = 'sign_example.txt'  # 數字簽名文件路徑key = b'\x01\x02\x03\x04\x05\x06\x07\x08\x09\x0a\x0b\x0c\x0d\x0e\x0f\x10'  # SM4算法密鑰iv = b'\x01\x02\x03\x04\x05\x06\x07\x08\x09\x0a\x0b\x0c\x0d\x0e\x0f\x10'  # SM4算法初始化向量private_key_path = '/root/sm2_private.pem'  # SM2算法私鑰文件路徑public_key_path = '/root/sm2_public.pem'    # SM2算法公鑰文件路徑password = "123456"  # 私鑰文件的密碼# 加密文件encrypt_file(input_file_path, encrypted_file_path, key, iv)# 解密文件decrypt_file(encrypted_file_path, decrypted_file_path, key, iv)# 生成數字簽名sign_file(private_key_path, password, input_file_path, sign_file_path)# 驗證數字簽名verify_result = verify_file_signature(public_key_path, input_file_path, sign_file_path)logging.info(f"數字簽名驗證結果:{verify_result}")# 檢查文件完整性hash_value = check_file_integrity(input_file_path)logging.info(f"文件的SM3哈希值:{hash_value}")

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

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

相關文章

HTML從入門到精通:鏈接與圖像標簽全解析

系列文章目錄 01-從零開始學 HTML:構建網頁的基本框架與技巧 02-HTML常見文本標簽解析:從基礎到進階的全面指南 03-HTML從入門到精通:鏈接與圖像標簽全解析 文章目錄 系列文章目錄前言一、鏈接與圖像標簽(HTML 標簽基礎&#xff…

[STM32 - 野火] - - - 固件庫學習筆記 - - -十一.電源管理系統

一、電源管理系統簡介 電源管理系統是STM32硬件設計和系統運行的基礎,它不僅為芯片本身提供穩定的電源,還通過多種電源管理功能優化功耗、延長電池壽命,并確保系統的可靠性和穩定性。 二、電源監控器 作用:保證STM32芯片工作在…

數字圖像處理:實驗六

uu們!大家好,2025年的新年就要到來,咸魚哥在這里祝大家在2025年每天開心快樂,天天掙大錢,自由自在,健健康康,萬事如意!(要是咸魚哥嘴笨的話,還望大家多多包涵…

Langchain+文心一言調用

import osfrom langchain_community.llms import QianfanLLMEndpointos.environ["QIANFAN_AK"] "" os.environ["QIANFAN_SK"] ""llm_wenxin QianfanLLMEndpoint()res llm_wenxin.invoke("中國國慶日是哪一天?") print(…

上海亞商投顧:滬指沖高回落 大金融板塊全天強勢 上海亞商投

上海亞商投顧前言:無懼大盤漲跌,解密龍虎榜資金,跟蹤一線游資和機構資金動向,識別短期熱點和強勢個股。 一.市場情緒 市場全天沖高回落,深成指、創業板指午后翻綠。大金融板塊全天強勢,天茂集團…

農產品價格報告爬蟲使用說明

農產品價格報告爬蟲使用說明 # ************************************************************************** # * * # * 農產品價格報告爬蟲 …

3.4 Go函數作用域(標識符)

作用域標識符 簡單來說,作用域指的是標識符可以起作用的范圍,即其可見范圍。將標識符的可見性限制在一定范圍內,這個范圍就是作用域。 把標識符約束在一定的可見范圍內,這個范圍就是作用域。 1. 宇宙塊 特點:預定義…

kaggle比賽入門 - House Prices - Advanced Regression Techniques(第二部分)

本文承接上一篇 1. 分析住宅類型(BldgType)的分布以及它們與銷售價格(SalePrice)的關系 # 1. distribution of dwelling types and their relation to sale prices # BldgType: Type of dwellingdwelling_types df[BldgType].v…

使用shell命令安裝virtualbox的虛擬機并導出到vagrant的Box

0. 安裝virtualbox and vagrant [rootolx79vagrant ~]# cat /etc/resolv.conf #search 114.114.114.114 nameserver 180.76.76.76-- install VirtualBox yum install oraclelinux-developer-release-* wget https://yum.oracle.com/RPM-GPG-KEY-oracle-ol7 -O /etc/pki/rpm-g…

【數據結構】空間復雜度

目錄 一、引入空間復雜度的原因 二、空間復雜度的分析 ? 2.1 程序運行時內存大小 ~ 程序本身大小 ? 2.2 程序運行時內存大小 ~ 算法運行時內存大小 ? 2.3 算法運行時內存大小 ? 2.4 不考慮算法全部運行空間的原因 三、空間復雜度 ? 3.1空間復雜度的定義 ? 3.2 空…

MySQL--》深度解析InnoDB引擎的存儲與事務機制

目錄 InnoDB架構 事務原理 MVCC InnoDB架構 從MySQL5.5版本開始默認使用InnoDB存儲引擎,它擅長進行事務處理,具有崩潰恢復的特性,在日常開發中使用非常廣泛,其邏輯存儲結構圖如下所示, 下面是InnoDB架構圖&#xf…

Redis高階5-布隆過濾器

Redis布隆過濾器 ? 由一個初始值都為零的bit數組和多個哈希函數構成,用來快速判斷集合中是否存在某個元素 目的減少內存占用方式不保存數據信息,只是在內存中做一個是否存在的標記flag 布隆過濾器(英語:Bloom Filter&#xff0…

DeepSeek學術題目選擇效果怎么樣?

論文選題 一篇出色的論文背后,必定有一個“智慧的選題”在撐腰。選題足夠好文章就能順利登上高水平期刊;選題不行再精彩的寫作也只能“當花瓶”。然而許多寶子們常常忽視這個環節,把大量時間花在寫作上,選題時卻像抓鬮一樣隨便挑一…

第五節 MATLAB命令

本節的內容將提供常用的一些MATLAB命令。 在之前的篇章中我們已經知道了MATLAB數值計算和數據可視化是一個交互式程序,在它的命令窗口中您可以在MATLAB提示符“>>”下鍵入命令。 MATLAB管理會話的命令 MATLAB提供管理會話的各種命令。如下表所示:…

Docker核心命令與Yocto項目的高效應用

隨著軟件開發逐漸向分布式和容器化方向演進,Docker 已成為主流的容器化技術之一。它通過標準化的環境配置、資源隔離和高效的部署流程,大幅提高了開發和構建效率。Yocto 項目作為嵌入式 Linux 系統構建工具,與 Docker 的結合進一步增強了開發…

Qt 5.14.2 學習記錄 —— ?? QFile和多線程

文章目錄 1、QFile1、打開2、讀寫3、關閉4、程序5、其它功能 2、多線程1、演示2、鎖 3、條件變量和信號量 1、QFile Qt有自己的一套文件體系,不過Qt也可以使用C,C,Linux的文件操作。使用Qt的文件體系和Qt自己的一些類型更好配合。 管理寫入讀…

【全棧】SprintBoot+vue3迷你商城-擴展:vue3項目創建及目錄介紹

【全棧】SprintBootvue3迷你商城-擴展:vue3項目創建及目錄介紹 往期的文章都在這里啦,大家有興趣可以看一下 【全棧】SprintBootvue3迷你商城(1) 【全棧】SprintBootvue3迷你商城(2) 【全棧】SprintBootvu…

使用Aardio庫在Python中創建桌面應用:簡單指南

引言 隨著軟件開發需求的不斷增長,開發者們需要更加靈活和高效的工具來快速構建應用程序。Python以其簡潔易讀的語法和強大的社區支持而聞名,但在創建圖形用戶界面(GUI)時,可能會遇到一些挑戰。Aardio作為一種輕量級的…

多版本并發控制:MVCC的作用和基本原理

多版本并發控制:MVCC的作用和基本原理 1、MVCC簡介1.1 快照讀與當前讀的區別1.1.1 快照讀1.1.2 當前讀 1.2 數據庫的讀寫問題1.3 MVCC的作用 2、MVCC實現原理之ReadView2.1 什么是ReadView2.2 ReadView的設計思路2.3 MVCC整體操作流程 1、MVCC簡介 1.1 快照讀與當前…

神經網絡|(二)sigmoid神經元函數

【1】引言 在前序學習進程中,我們已經了解了基本的二元分類器和神經元的構成,文章學習鏈接為: 神經網絡|(一)加權平均法,感知機和神經元-CSDN博客 在此基礎上,我們認識到神經元本身在做二元分類,是一種非…