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

wordpress金融网站模板wordpress小工具添加底部

wordpress金融网站模板,wordpress小工具添加底部,域名网站教程,长春网站制作可选吉网传媒好[密码学实战]彻底理解位(bit)与字节(byte)在十六进制处理中的区别 一、为什么需要区分位和字节? 在密码学开发中,SM2、AES等算法的密钥长度常以位(bit)为单位描述,而实际代码操作却以字节(byte)为基本单位。这种差异若理解不透彻&#xff0…

[密码学实战]彻底理解位(bit)与字节(byte)在十六进制处理中的区别

一、为什么需要区分位和字节?

在密码学开发中,SM2、AES等算法的密钥长度常以位(bit)为单位描述,而实际代码操作却以字节(byte)为基本单位。这种差异若理解不透彻,极易导致以下问题:

  • 缓冲区溢出:分配内存时混淆单位
  • 密钥截断:错误处理Hex字符串导致密钥强度降低
  • 跨平台兼容性问题:不同系统对数据类型解释不同

二、核心概念对比

1. 基本定义

单位符号大小典型应用场景
位(bit)b0或1描述算法强度(如SM2=256b)
字节(byte)B8位内存分配、网络传输

2. 十六进制(Hex)的特殊性

十六进制是字节的人类可读表示形式

  • 1字节 = 2个Hex字符(范围00~FF
  • 重要公式
    密钥位数 = Hex字符串长度 × 4
    示例:64字符Hex → 64×4=256位密钥
    

三、SM2密钥的三种表示形式

以256位SM2密钥为例:

1. 位表示(理论值)

key_bits = 256  # 仅用于描述长度

2. 字节数组(内存存储)

uint8_t key_bytes[32] = { 0x00, 0x01, ..., 0xFF 
}; // 32字节=256位

3. Hex字符串(可读格式)

char hex_str[65] = "0001...FFFF"; // 64字符

四、关键代码实现

1. 字节数组 ↔ Hex字符串转换

// Hex转字节数组(安全版)
int hex_to_bytes(const char *hex, uint8_t *bytes, size_t len) {if (strlen(hex) != len*2) return -1;for (size_t i = 0; i < len; i++) {if (sscanf(hex + 2*i, "%02hhx", &bytes[i]) != 1) {return -1;}}return 0;
}// 字节数组转Hex(线程安全版)
void bytes_to_hex(const uint8_t *bytes, char *hex, size_t len) {for (size_t i = 0; i < len; i++) {snprintf(hex + 2*i, 3, "%02x", bytes[i]);}
}

2. 密钥长度验证

bool is_valid_sm2_key(const char *hex) {const size_t hex_len = 64; // SM2的256位对应64字符Hexif (strlen(hex) != hex_len) return false;for (size_t i = 0; i < hex_len; i++) {if (!isxdigit(hex[i])) return false;}return true;
}

五、开发中的常见陷阱

陷阱1:未初始化内存

// 错误示例
char hex[64]; // 未初始化,缺少NULL终止符
sprintf(hex, ...); // 可能越界// 正确做法
char hex[65] = {0}; // 预留NULL位置

陷阱2:大小写敏感问题

// 兼容大小写的比较方法
if (strncasecmp(hex1, hex2, 64) != 0) {// 密钥不匹配
}

陷阱3:跨平台差异

  • Windows x86默认char是有符号的
  • 建议使用uint8_t代替unsigned char

六、实战案例:SM2密钥生成API

#include <openssl/sm2.h>int generate_sm2_keypair(char **pubkey_hex, char **prikey_hex) {EC_KEY *key = EC_KEY_new_by_curve_name(NID_sm2);if (!key || !EC_KEY_generate_key(key)) return -1;// 提取公钥(04||X||Y格式)const EC_POINT *pub = EC_KEY_get0_public_key(key);uint8_t pub_bytes[65]; // 04 + 32(X) + 32(Y)EC_POINT_point2oct(..., pub_bytes, sizeof(pub_bytes), ...);// 提取私钥const BIGNUM *pri = EC_KEY_get0_private_key(key);uint8_t pri_bytes[32];BN_bn2bin(pri, pri_bytes);// 转换为Hex*pubkey_hex = malloc(65*2 + 1);*prikey_hex = malloc(64 + 1);bytes_to_hex(pub_bytes, *pubkey_hex, 65);bytes_to_hex(pri_bytes, *prikey_hex, 32);EC_KEY_free(key);return 0;
}

七、总结

操作输入输出工具函数
生成密钥256位参数32字节数组EC_KEY_generate_key
字节→Hex32字节数组64字符字符串bytes_to_hex
Hex→字节64字符字符串32字节数组hex_to_bytes

八、延伸思考

  1. 性能优化:查表法替代sprintf实现更快的Hex转换
  2. 安全增强:使用secure_memset清空敏感内存

希望本教程对您有帮助,请点赞❤️收藏⭐关注支持!欢迎在评论区留言交流技术细节!

http://www.dtcms.com/wzjs/786534.html

相关文章:

  • 网站优化要多少钱怎么做小程序
  • 咨询网站模板wordpress信息修改
  • 搜索网站存在的关键字百度统计 网站速度诊断
  • 学习网站建设论文wordpress定时任务
  • 惠州惠城网站建设北京网站建设公司华网天下下
  • 微信公众商城网站开发模板网站更改
  • 网站影响seo的标签网页设计与制作课程结构
  • 做网站的上海公司有哪些网站运营成本明细
  • 厦门网站建设方案维护深圳市网站建设有限公司
  • 婚礼网站怎么做的o2o平台运营是什么意思
  • 学做糕点的网站福建建设中心网站
  • 莒县做网站的公司建设网站注意实现
  • 新源网站建设如何用万网建设网站
  • 大连房地产网站建设工作室和公司的区别
  • 自己怎么优化我网站关键词wordpress模板命名规则
  • 昆山网站排名优化站长之家whois
  • 邢台专业网站建设推荐岳阳注册公司
  • 贵州省城乡和住房建设厅网站广告留电话号的网站
  • 怎么搜索整个网站内容全国建筑工程企业资质查询平台
  • 电子商务网站设计成功的要素织梦视频网站模板
  • 医院网站推广渠道百度seo站长工具
  • 有没有做语文题的网站杭州网站设计询问蓝韵网络
  • 网站建设评审意见同一虚拟主机 2个网站
  • 小当网 绵阳网站建设企业网站运营方案
  • o2o网站建设市场产品宣传短视频
  • 龙港做网站店铺万全做网站wl17581
  • 购物网站技术实施方案网站建设的合同
  • 网站后台地址一般是知名的摄影网站有哪些
  • 云南房地产网站建设网络推广应该怎么做啊
  • 网站建设需要在网络上如何实现ps做网站效果图