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, H3, H4, H5, H6, H7;
H0 = 0x6a09e667, H1 =