sm3算法封装

文章介绍了如何实现SM3算法,包括init、update、done三个步骤,并提供了专门针对小数据的快速计算函数。此外,还讨论了上下文重置的重要性,以支持在同一上下文中进行多次摘要计算,可以通过内联函数或宏定义实现重置功能。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

通过前面那些章节,我们已经实现了sm3算法,共分为initupdatedone三部分来实现的,调用的时候呢,就按以下方式调用即可:

Created with Raphaël 2.3.0initupdate消息全部计算完doneyesno

针对大文件,可以使用这三部来一点一点的计算,直到文件全部读取完,但是针对一些小数据,比如就几百字节,也要分三次调用,就显得有点繁琐了,所以再定义一个函数,专门用于小数据计算的,定义如下:

/**
 * 直接计算消息的摘要
 * @param input 消息
 * @param iLen 消息长度(字节)
 * @param output 输出摘要结果
 */
void gm_sm3(const unsigned char * input, unsigned int iLen, unsigned char output[32]);

用户不需要知道,函数里面具体是如何实现的,只要输入待计算的消息,以及转入输出缓冲区即可,由函数自身来帮忙调用initupdatedone这三部,实现代码如下:

/**
 * 直接计算消息的摘要
 * @param input 消息
 * @param iLen 消息长度(字节)
 * @param output 输出摘要结果
 */
void gm_sm3(const unsigned char * input, unsigned int iLen, unsigned char output[32]) {
    gm_sm3_context ctx;
    gm_sm3_init(&ctx);
    gm_sm3_update(&ctx, input, iLen);
    gm_sm3_done(&ctx, output);
}

另外,可能还会有一些需要复用同一个上下文的场景,比如一个函数内需要计算多次sm3摘要,又不想分配多个上下文,那么用完后,需要对上下文进行重置,下次才能继续用。在sm3.h增加如下代码:

/**
 * 重置上下文,以达到复用此上下文的目的
 * @param ctx 上下文
 */
inline void gm_sm3_reset(gm_sm3_context * ctx) {
    gm_sm3_init(ctx);
}

无非就是重置一下那8个字寄存器,以及一些中间状态,当然除了内联函数,还可以用宏定义来实现,比如:

#define GM_SM3_RESET(ctx) gm_sm3_init(ctx)

大家自己按喜好选一种即可。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值