【修正BUG】SHA-256算法 C语言实现

博客介绍了修正后的SHA-256算法C语言实现,包括计算字符串和文件的SHA-256值。算法参考自Federal.Information.Processing.Standards.Publication.180-2.pdf,可在VS2013环境下编译运行。针对可能出现的编译问题和使用疑问,如_ftelli64未定义,作者提供了相应的解决方案,并提供了在线验证工具。

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

SHA-256算法 C语言实现

感谢 qq_20453319 提醒,现已修正BUG

实现了计算字符串,文件的SHA-256值
算法来自:

Federal.Information.Processing.Standards.Publication.180-2.pdf
下载文档

VS2013下成功编译运行


针对评论区出现的疑问,在这里说明一下:
1.如果出现 _ftelli64未定义 的错误,将_ftelli64替换为ftello64。visual c应该不会有这种错误。
2.函数的第三个参数是计算后的字符串形式,不需要再转换,详情看示例代码。
3.默认计算结果是大写形式,如需小写,将函数中末尾处所有 %08X 替换为 %08x 即可。

/*用法示例*/
#include <stdio.h>
#include <stdlib.h>

extern char* StrSHA256(const char* str, long long length, char* sha256);

int main(void){
    char text[] = "blackkitty";
    char sha256[65];
    StrSHA256(text,sizeof(text)-1,sha256);  // sizeof()计算的结果包含了末尾的'\0'应减1
    puts(sha256);
    puts(StrSHA256(text,sizeof(text)-1,sha256));    // 函数返回值即sha256,直接输出也可以
    return 0;
}

这里写图片描述

使用在线加密验证http://tool.oschina.net/encrypt?type=2


代码如下:

#include <stdio.h>
#include <stdlib.h>
#define SHA256_ROTL(a,b) (((a>>(32-b))&(0x7fffffff>>(31-b)))|(a<<b))
#define SHA256_SR(a,b) ((a>>b)&(0x7fffffff>>(b-1)))
#define SHA256_Ch(x,y,z) ((x&y)^((~x)&z))
#define SHA256_Maj(x,y,z) ((x&y)^(x&z)^(y&z))
#define SHA256_E0(x) (SHA256_ROTL(x,30)^SHA256_ROTL(x,19)^SHA256_ROTL(x,10))
#define SHA256_E1(x) (SHA256_ROTL(x,26)^SHA256_ROTL(x,21)^SHA256_ROTL(x,7))
#define SHA256_O0(x) (SHA256_ROTL(x,25)^SHA256_ROTL(x,14)^SHA256_SR(x,3))
#define SHA256_O1(x) (SHA256_ROTL(x,15)^SHA256_ROTL(x,13)^SHA256_SR(x,10))
extern char* StrSHA256(const char* str, long long length, char* sha256){
    /*
    计算字符串SHA-256
    参数说明:
    str         字符串指针
    length      字符串长度
    sha256         用于保存SHA-256的字符串指针
    返回值为参数sha256
    */
    char *pp, *ppend;
    long l, i, W[64], T1, T2, A, B, C, D, E, F, G, H, H0, H1, H2, 
评论 30
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值