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

BouncyCastle SM2/SM3/SM4

BouncyCastle SM2/SM3/SM4 为啥这些人命名的不是SM1, SM3 非对称SM2 SM4 对称!-- BouncyCastle 国密核心依赖 -- dependency groupIdorg.bouncycastle/groupId artifactIdbcprov-jdk18on/artifactId version1.78.5/version /dependencyimport org.bouncycastle.jce.provider.BouncyCastleProvider; import java.security.Security; // 全局注册一次即可 static { if (Security.getProvider(BouncyCastleProvider.PROVIDER_NAME) null) { Security.addProvider(new BouncyCastleProvider()); } }import org.bouncycastle.crypto.digests.SM3Digest; import org.bouncycastle.util.encoders.Hex; /** * SM3 哈希加密 * param data 明文 * return 64位十六进制哈希串 */ public static String sm3Encrypt(String data) { byte[] srcData data.getBytes(); SM3Digest sm3Digest new SM3Digest(); sm3Digest.update(srcData, 0, srcData.length); byte[] digest new byte[sm3Digest.getDigestSize()]; sm3Digest.doFinal(digest, 0); // 转为十六进制字符串 return Hex.toHexString(digest); } // 测试 public static void main(String[] args) { String text 测试国密SM3加密; String result sm3Encrypt(text); System.out.println(SM3哈希值 result); }import org.bouncycastle.crypto.engines.SM4Engine; import org.bouncycastle.crypto.modes.CBCBlockCipher; import org.bouncycastle.crypto.paddings.PKCS7Padding; import org.bouncycastle.crypto.paddings.PaddedBufferedBlockCipher; import org.bouncycastle.crypto.params.KeyParameter; import org.bouncycastle.crypto.params.ParametersWithIV; import org.bouncycastle.util.encoders.Hex; import java.nio.charset.StandardCharsets; import java.security.SecureRandom; /** * SM4 对称加密CBC模式 */ public class SM4Util { private static final int SM4_KEY_LENGTH 16; // SM4 密钥固定16字节 private static final int IV_LENGTH 16; // 生成随机 SM4 密钥16字节 public static String generateSm4Key() { byte[] key new byte[SM4_KEY_LENGTH]; new SecureRandom().nextBytes(key); return Hex.toHexString(key); } // 生成随机 IV public static String generateIv() { byte[] iv new byte[IV_LENGTH]; new SecureRandom().nextBytes(iv); return Hex.toHexString(iv); } /** * SM4 加密 */ public static String sm4Encrypt(String plainText, String keyHex, String ivHex) throws Exception { byte[] key Hex.decode(keyHex); byte[] iv Hex.decode(ivHex); byte[] data plainText.getBytes(StandardCharsets.UTF_8); PaddedBufferedBlockCipher cipher new PaddedBufferedBlockCipher( new CBCBlockCipher(new SM4Engine()), new PKCS7Padding()); cipher.init(true, new ParametersWithIV(new KeyParameter(key), iv)); byte[] encrypted new byte[cipher.getOutputSize(data.length)]; int len cipher.processBytes(data, 0, data.length, encrypted, 0); len cipher.doFinal(encrypted, len); return Hex.toHexString(encrypted, 0, len); } /** * SM4 解密 */ public static String sm4Decrypt(String cipherText, String keyHex, String ivHex) throws Exception { byte[] key Hex.decode(keyHex); byte[] iv Hex.decode(ivHex); byte[] data Hex.decode(cipherText); PaddedBufferedBlockCipher cipher new PaddedBufferedBlockCipher( new CBCBlockCipher(new SM4Engine()), new PKCS7Padding()); cipher.init(false, new ParametersWithIV(new KeyParameter(key), iv)); byte[] decrypted new byte[cipher.getOutputSize(data.length)]; int len cipher.processBytes(data, 0, data.length, decrypted, 0); len cipher.doFinal(decrypted, len); return new String(decrypted, 0, len, StandardCharsets.UTF_8); } // 测试 public static void main(String[] args) throws Exception { String text 测试国密SM4加密; String key generateSm4Key(); String iv generateIv(); String encrypt sm4Encrypt(text, key, iv); String decrypt sm4Decrypt(encrypt, key, iv); System.out.println(密钥 key); System.out.println(加密结果 encrypt); System.out.println(解密结果 decrypt); } }import org.bouncycastle.crypto.AsymmetricCipherKeyPair; import org.bouncycastle.crypto.params.ECPrivateKeyParameters; import org.bouncycastle.crypto.params.ECPublicKeyParameters; import org.bouncycastle.crypto.util.PrivateKeyFactory; import org.bouncycastle.crypto.util.PublicKeyFactory; import org.bouncycastle.jce.provider.BouncyCastleProvider; import org.bouncycastle.util.encoders.Hex; import java.security.Security; // SM2 工具类 public class SM2Util { static { if (Security.getProvider(BouncyCastleProvider.PROVIDER_NAME) null) { Security.addProvider(new BouncyCastleProvider()); } } /** * 生成 SM2 密钥对公钥私钥 */ public static AsymmetricCipherKeyPair generateSm2KeyPair() { org.bouncycastle.crypto.generators.ECKeyPairGenerator generator new org.bouncycastle.crypto.generators.ECKeyPairGenerator(); generator.init(new org.bouncycastle.crypto.params.ECKeyGenerationParameters( org.bouncycastle.jce.ECNamedCurveTable.getParameterSpec(sm2p256v1).getDomainParameters(), new java.security.SecureRandom() )); return generator.generateKeyPair(); } // 公钥转十六进制 public static String publicKeyToHex(ECPublicKeyParameters publicKey) { return Hex.toHexString(publicKey.getQ().getEncoded(false)); } // 私钥转十六进制 public static String privateKeyToHex(ECPrivateKeyParameters privateKey) { return Hex.toHexString(privateKey.getD().toByteArray()); } /** * SM2 公钥加密 */ public static String sm2Encrypt(String data, String publicKeyHex) throws Exception { ECPublicKeyParameters publicKey (ECPublicKeyParameters) PublicKeyFactory.createKey(Hex.decode(publicKeyHex)); org.bouncycastle.crypto.engines.SM2Engine engine new org.bouncycastle.crypto.engines.SM2Engine(); engine.init(true, publicKey); byte[] encrypted engine.processBlock(data.getBytes(), 0, data.getBytes().length); return Hex.toHexString(encrypted); } /** * SM2 私钥解密 */ public static String sm2Decrypt(String cipherText, String privateKeyHex) throws Exception { ECPrivateKeyParameters privateKey (ECPrivateKeyParameters) PrivateKeyFactory.createKey(Hex.decode(privateKeyHex)); org.bouncycastle.crypto.engines.SM2Engine engine new org.bouncycastle.crypto.engines.SM2Engine(); engine.init(false, privateKey); byte[] decrypted engine.processBlock(Hex.decode(cipherText), 0, Hex.decode(cipherText).length); return new String(decrypted); } // 测试 public static void main(String[] args) throws Exception { // 生成密钥对 AsymmetricCipherKeyPair keyPair generateSm2KeyPair(); ECPublicKeyParameters publicKey (ECPublicKeyParameters) keyPair.getPublic(); ECPrivateKeyParameters privateKey (ECPrivateKeyParameters) keyPair.getPrivate(); String publicKeyHex publicKeyToHex(publicKey); String privateKeyHex privateKeyToHex(privateKey); String text 测试国密SM2加密; String encrypt sm2Encrypt(text, publicKeyHex); String decrypt sm2Decrypt(encrypt, privateKeyHex); System.out.println(公钥 publicKeyHex); System.out.println(私钥 privateKeyHex); System.out.println(加密 encrypt); System.out.println(解密 decrypt); } }emo国标加密解密

相关文章:

BouncyCastle SM2/SM3/SM4

BouncyCastle SM2/SM3/SM4为啥这些人命名的不是SM1, SM3 非对称&#xff1b;SM2 SM4 对称<!-- BouncyCastle 国密核心依赖 --> <dependency><groupId>org.bouncycastle</groupId><artifactId>bcprov-jdk18on</artifactId><versi…...

万字拆解 LLM 运行机制:Token、上下文与采样参数暮

springboot自动配置 自动配置了大量组件&#xff0c;配置信息可以在application.properties文件中修改。 当添加了特定的Starter POM后&#xff0c;springboot会根据类路径上的jar包来自动配置bean&#xff08;比如&#xff1a;springboot发现类路径上的MyBatis相关类&#xff…...

AI开发-python-langchain框架(--自定义Tool )挪

起因是我想在搞一些操作windows进程的事情时&#xff0c;老是需要右键以管理员身份运行&#xff0c;感觉很麻烦。就研究了一下怎么提权&#xff0c;顺手瞄了一眼Windows下用户态权限分配&#xff0c;然后也是感谢《深入解析Windows操作系统》这本书给我偷令牌的灵感吧&#xff…...

DABShield数字广播扩展板嵌入式驱动开发指南

1. DABShield 数字广播扩展板技术解析与嵌入式驱动开发指南DABShield 是一款面向嵌入式平台的高集成度数字广播接收扩展板&#xff0c;专为 Arduino、STM32、ESP32 等主流微控制器设计&#xff0c;支持 DAB&#xff08;Digital Audio Broadcasting&#xff09;、DAB&#xff08…...

LSM6DS0超低功耗六轴IMU硬件原理与嵌入式驱动实战

1. LSM6DS0&#xff1a;面向嵌入式实时系统的六轴惯性测量单元深度解析 LSM6DS0 是意法半导体&#xff08;STMicroelectronics&#xff09;于2014年推出的超低功耗、高精度六轴惯性测量单元&#xff08;IMU&#xff09;&#xff0c;集成三轴加速度计与三轴陀螺仪于单一封装内。…...

Windows右键菜单管理神器:ContextMenuManager让你的操作效率翻倍

Windows右键菜单管理神器&#xff1a;ContextMenuManager让你的操作效率翻倍 【免费下载链接】ContextMenuManager &#x1f5b1;️ 纯粹的Windows右键菜单管理程序 项目地址: https://gitcode.com/gh_mirrors/co/ContextMenuManager 你是否厌倦了Windows右键菜单被各种…...

AVRDx平台ISR型PWM库:高确定性多路软件PWM方案

1. Dx_Slow_PWM 库深度解析&#xff1a;面向 AVRDx 平台的高可靠性 ISR 基础 PWM 解决方案1.1 工程背景与核心痛点在嵌入式系统开发中&#xff0c;PWM&#xff08;脉宽调制&#xff09;是驱动电机、LED 调光、音频生成、电源控制等场景的基础能力。AVR 系列微控制器传统上依赖专…...

matlab代码:储能参与电能量—辅助服务调频市场联合出清代码。 本代码是电力市场出清的一个重要方向

matlab代码&#xff1a;储能参与电能量—辅助服务调频市场联合出清代码。本代码是电力市场出清的一个重要方向&#xff0c;由于储能的诸多特性&#xff0c;使其适合于辅助服务市场的调频市场&#xff0c;储能的参与也能获利。 首先利用SCUC模型确定机组出力计划和储能充放电计划…...

别再乱选了!SMT贴片新手必看:卷带、托盘、管式、散装四种元器件包装的保姆级选择指南

SMT贴片元器件包装选择实战指南&#xff1a;从卷带到散装的深度解析 刚踏入SMT产线的新手工程师&#xff0c;面对BOM表上密密麻麻的包装代码&#xff08;Tape on Reel、Tray、Tube、Bulk&#xff09;时&#xff0c;往往会陷入选择困境。选错包装类型可能导致生产效率腰斩、物料…...

ESP32/ESP8266轻量级WiFi配置门户与多凭证管理

1. ESP_WiFiManagerLite2 库深度解析&#xff1a;轻量级多WiFi凭证管理与运行时配置方案1.1 项目定位与工程价值ESP_WiFiManagerLite2 是专为 ESP32 和 ESP8266 系列微控制器设计的轻量级 WiFi 凭证管理与配置门户&#xff08;Config Portal&#xff09;库。其核心设计哲学是“…...

Gitee仓库管理实战:从零开始掌握本地文件推送全流程

1. 环境准备&#xff1a;从零搭建Git与Gitee桥梁 第一次接触代码版本控制的新手&#xff0c;往往会对着满屏的命令行感到手足无措。其实Git就像个智能文件管家&#xff0c;而Gitee相当于云端保险柜。我刚开始用Git时&#xff0c;最头疼的就是明明本地文件改好了&#xff0c;却总…...

终极指南:使用SRWE窗口编辑器轻松突破Windows窗口限制

终极指南&#xff1a;使用SRWE窗口编辑器轻松突破Windows窗口限制 【免费下载链接】SRWE Simple Runtime Window Editor 项目地址: https://gitcode.com/gh_mirrors/sr/SRWE SRWE窗口编辑器是一款专为Windows用户设计的革命性工具&#xff0c;让你能够实时调整任何应用程…...

VS Code 语义化代码高亮:如何为不同语法元素定制专属色彩

1. 为什么需要语义化代码高亮&#xff1f; 写代码就像在画一幅复杂的画&#xff0c;不同颜色的颜料能帮助我们快速区分画面中的各个元素。想象一下如果整幅画只用黑色线条勾勒&#xff0c;即使结构再清晰&#xff0c;看起来也会很吃力。代码阅读也是同样的道理——当所有变量、…...

VideoAgentTrek Screen Filter开发指南:使用Git进行版本管理与协作

VideoAgentTrek Screen Filter开发指南&#xff1a;使用Git进行版本管理与协作 如果你正在基于VideoAgentTrek Screen Filter进行二次开发&#xff0c;无论是修改AI模型推理逻辑&#xff0c;还是调整视频过滤规则&#xff0c;很快你就会遇到一个现实问题&#xff1a;代码怎么管…...

高性能客服系统技术内幕:通过 SpinWait 自旋等待结构体提升高频消息分发性能挥

1. 智能软件工程的范式转移&#xff1a;从库集成到原生框架演进 在生成式人工智能&#xff08;Generative AI&#xff09;从单纯的文本生成向具备自主规划与执行能力的“代理化&#xff08;Agentic&#xff09;”系统跨越的过程中&#xff0c;.NET 生态系统正在经历一场自该平台…...

把近万个源文件喂给AI之前,我先做了一件事猛

插件化架构 v3 版本最大的变化是引入了模块化插件系统。此前版本中集成在核心包里的原生功能&#xff0c;现在被拆分成独立的插件。 每个插件都是一个独立的 Composer 包&#xff0c;包含 Swift 和 Kotlin 代码、权限清单以及原生依赖。开发者只需安装实际用到的插件&#xff0…...

【国家级AI安全合规指南】:基于GB/T 44503-2024标准的6层对齐验证体系实战拆解

第一章&#xff1a;大模型工程化安全与对齐策略的顶层范式演进 2026奇点智能技术大会(https://ml-summit.org) 大模型工程化已从单点能力验证阶段&#xff0c;跃迁至以系统性安全治理与价值对齐为内核的范式重构期。这一演进并非技术栈的线性叠加&#xff0c;而是安全目标、对…...

【2026奇点大会官方内参】:大模型微调5大避坑指南(含Meta/DeepSeek一线工程师未公开参数配置)

第一章&#xff1a;2026奇点智能技术大会&#xff1a;大模型微调最佳实践 2026奇点智能技术大会(https://ml-summit.org) 数据准备的核心原则 高质量微调始于精准的数据治理。训练样本需满足领域对齐、语义完整性与标注一致性三重标准。建议采用分层采样策略&#xff1a;70% …...

JavaWeb技术全景解析:从核心组件到实战架构

1. JavaWeb技术全景概览 当你第一次接触JavaWeb开发时&#xff0c;可能会被各种术语和概念搞得晕头转向。别担心&#xff0c;这就像学做菜一样&#xff0c;刚开始分不清酱油和醋很正常。JavaWeb本质上就是用Java技术来开发网站和Web应用的一套解决方案&#xff0c;它能让你的程…...

数据分析三件套:Numpy、Pandas、Matplotlib

目录 一、 环境准备与安装 1.1 确认Python环境 1.2 使用pip一键安装 1.3 验证安装是否成功 二、 NumPy&#xff1a;数组计算的基石 2.1 什么是NumPy&#xff1f; 2.2 创建数组的四种方式 2.3 数组的常用操作 2.3.1 形状操作 2.3.2 数学运算 2.3.3 索引与切片 2.4 Nu…...

避坑指南:调整Intel/AMD平台PCIe超时设置前,你必须知道的CPU内部Timer架构

深入解析Intel/AMD平台PCIe超时机制&#xff1a;系统架构师必须了解的CPU内部Timer设计 在当今高性能计算和低延迟网络应用中&#xff0c;PCIe设备的稳定性和性能优化成为系统架构师面临的核心挑战之一。当FPGA加速卡突然停止响应&#xff0c;或者100G网卡出现间歇性数据丢失时…...

Win10家庭版用户必看:用傲梅分区助手克隆硬盘时如何避免RAW格式(附BitLocker解决方案)

Win10家庭版硬盘克隆避坑指南&#xff1a;傲梅分区助手与BitLocker加密的实战解决方案 最近帮朋友处理一台联想小新Air14的硬盘扩容需求时&#xff0c;遇到了一个颇具代表性的问题&#xff1a;使用傲梅分区助手克隆完硬盘后&#xff0c;目标盘突然变成了无法识别的RAW格式。这个…...

Pokerobo_RCB嵌入式遥控器驱动库:摇杆、nRF24、12864 LCD协同设计

1. Pokerobo_RCB 库概述Pokerobo_RCB 是一个面向嵌入式遥控器硬件平台的专用驱动与控制库&#xff0c;核心目标是将三类关键外设——模拟摇杆&#xff08;Joystick&#xff09;、nRF24L01 射频收发模块、ST7920 驱动的 12864 点阵液晶&#xff08;12864 LCD&#xff09;——在单…...

Springboot 实现多数据源(PostgreSQL 和 SQL Server)连接倩

一、环境准备 Free Spire.Doc for Python 是免费 Python 文档处理库&#xff0c;无需依赖 Microsoft Word&#xff0c;支持 Word 文档的创建、编辑、转换等操作&#xff0c;其中内置的 Markdown 解析能力&#xff0c;能高效实现 Markdown 到 Doc/Docx 格式的转换&#xff0c;且…...

SDHCFileSystem:嵌入式高可靠FAT文件系统实现

1. SDHCFileSystem 库深度解析&#xff1a;面向嵌入式系统的高可靠性 SD/SDHC 卡文件系统实现1.1 库定位与工程价值SDHCFileSystem 是一个专为资源受限嵌入式平台设计的轻量级、可移植、生产就绪型 FAT 文件系统中间件。其核心目标并非替代成熟的 FatFS 或 LittleFS&#xff0c…...

周红伟:替代龙虾的是什么?从 OpenClaw 到 Hermes:会自己长大的 AI 代理

这篇文章介绍了由 Nous Research 开发的开源 AI 代理 Hermes Agent。与前代产品 OpenClaw 相比&#xff0c;Hermes 最大的突破在于内置了完整的学习闭环——能从经验中自动创建和优化技能、跨会话记忆用户偏好&#xff0c;真正实现"越用越聪明"。文章涵盖项目核心特性…...

QTableWidget 表格组件故

7.1 初识三维模型 7.1.1 三维模型的数据载体 随着计算机图形技术的发展&#xff0c;我们或多或少都会见过或者听说过三维模型。笔者始终记得小时候第一次在电视上看到三维动画《变形金刚&#xff1a;超能勇士》的震撼感受&#xff1b;而现在我们已经可以在手机上玩三维游戏《王…...

告别OpenAI API费用!用Ollama+crewAI搭建免费本地AI工作流(保姆级避坑指南)

零成本构建本地AI工作流&#xff1a;Ollama与crewAI深度整合实战指南 在技术迭代日新月异的今天&#xff0c;大型语言模型已成为开发者工具箱中不可或缺的一部分。然而&#xff0c;商业API的高昂成本和网络限制常常让个人开发者和小型团队望而却步。本文将带你探索如何利用Olla…...

BMI088六轴IMU驱动开发:通信配置、同步机制与工程调优

1. BMI088六轴IMU底层驱动技术深度解析1.1 器件特性与工程定位Bosch Sensortec BMI088是一款面向高动态场景的系统级封装&#xff08;SiP&#xff09;六轴惯性测量单元&#xff0c;其核心价值不在于参数堆砌&#xff0c;而在于针对无人机、机器人等振动敏感平台的系统级鲁棒性设…...

MCP23S17 SPI端口扩展器原理与Arduino驱动实战

1. MCP23S17 嵌入式SPI端口扩展器深度技术解析MCP23S17 是 Microchip 公司推出的 16 通道、SPI 接口的可编程 I/O 端口扩展芯片&#xff0c;广泛应用于资源受限的嵌入式系统中&#xff0c;用于扩展主控 MCU 的 GPIO 数量。其核心价值在于以极低的硬件开销&#xff08;仅需 4 根…...