当前位置: 首页 > news >正文

pythonSM4加密

 数据安全法及密评要求,敏感数据系统需要使用国密算法进行加解密处理。

敏感数使用SM4/ECB加解密方式

#密钥参数epidemic_key
#加密信息参数 message
#加密算法SM4/ECB/PKCS5Padding
#加密类型SM4-ECB
#添加模式PKCS5Padding

from cryptography.hazmat.primitives.ciphers import Cipher, algorithms, modes
from cryptography.hazmat.backends import default_backend
import binascii
#密钥参数epidemic_key
#加密信息参数 message
#加密算法SM4/ECB/PKCS5Padding
#加密类型SM4-ECB
#添加模式PKCS5Padding
def sm4_encrypt_ecb(data, key):cipher = Cipher(algorithms.SM4(binascii.unhexlify(key)), modes.ECB(), backend=default_backend())encryptor = cipher.encryptor()# Use PKCS7 paddingpadded_data = data.encode('utf-8') + bytes([16 - len(data) % 16] * (16 - len(data) % 16))ciphertext = encryptor.update(padded_data) + encryptor.finalize()return binascii.hexlify(ciphertext).decode('utf-8')def sm4_decrypt_ecb(ciphertext, key):cipher = Cipher(algorithms.SM4(binascii.unhexlify(key)), modes.ECB(), backend=default_backend())decryptor = cipher.decryptor()decrypted_data = decryptor.update(binascii.unhexlify(ciphertext)) + decryptor.finalize()# Remove PKCS7 paddingreturn decrypted_data.rstrip(b'\x00').decode('utf-8')def main():epidemic_key = "4d18850d763e8748ff2f8d83530e0123"message = "123456"encrypted_message = sm4_encrypt_ecb(message, epidemic_key)print(f"Original Message: {message}")print(f"Encrypted Message: {encrypted_message}")decrypted_message = sm4_decrypt_ecb(encrypted_message, epidemic_key)print(f"Decrypted Message: {decrypted_message}")if __name__ == "__main__":main()

账户口令加密采用SM3进行hash 

from cryptography.hazmat.backends import default_backend
from cryptography.hazmat.primitives import hashes
import hashlib
def sm3_hash(data):digest = hashes.Hash(hashes.SM3(), backend=default_backend())digest.update(data.encode('utf-8'))return digest.finalize()
def main1():message = "闫三"hash_value = sm3_hash(message).hex()print(f"Message: {message}")print(f"SM3 Hash: {hash_value}")def md5_hash(data):md5 = hashlib.md5()md5.update(data.encode('utf-8'))return md5.hexdigest()
def main():message = "123456"hash_value = md5_hash(message)print(f"Message: {message}")print(f"MD5 Hash: {hash_value}")
if __name__ == "__main__":main1()main()
http://www.lryc.cn/news/289733.html

相关文章:

  • JSP在线阅读系统myeclipse定制开发SQLServer数据库网页模式java编程jdbc
  • el-date-picker设置default-time的默认时间
  • List集合根据对象某个元素去重
  • QML Qt4版本移植到Qt5概述
  • 【极数系列】Flink环境搭建Linux版本 (03)
  • 2023年深圳市节假日人口迁入数据,shp/excel格式,需要自取!
  • Windows10上通过MSYS2编译FFmpeg 6.1.1源码操作步骤
  • HiveSQL题——用户连续登陆
  • 题解仅供学习使用
  • Linux命令-apt-get命令(Debian Linux发行版中的APT软件包管理工具)
  • matlab appdesigner系列-仪器仪表3-旋钮
  • 常见の算法5
  • MYSQL中group by分组查询的用法详解(where和having的区别)!
  • 架构篇25:高可用存储架构-双机架构
  • 微信小程序(十五)自定义导航栏
  • Python3进行pdf文件分割及转word
  • 深入理解TCP网络协议(1)
  • QT 中如何使用 JSON 功能?
  • C++面试:算法的执行效率和资源消耗、时间和空间复杂度分析根据实际场景,选用合适的数据结构和算法进行程序设计
  • 力扣100215-按键变更的次数
  • STM32-GPIO输出(HAL库)
  • 倒计时80天
  • PBM模型参数详解
  • 贪吃蛇/链表实现(C/C++)
  • Qlik Sense : IntervalMatch(离散匹配)
  • MySql45讲-08.事务到底是隔离的还是不隔离的?(结合MVCC视频)
  • 备战蓝桥杯----数据结构及STL应用(基础2)
  • 日常学习之:vue + django + docker + heroku 对后端项目 / 前后端整体项目进行部署
  • LangGraph:一个基于LangChain构建的AI库,用于创建具有状态、多参与者的应用程序
  • 04-Nacos-服务注册基于spring boot实现