sha1:
openssl提供了sha1的库,在安装openssl以后能够直接调用sha1。
MD5:
函数原型见附件,其中static void MDFile (filename)是对文件进行MD5校验的,static void MDString (inString)是对字符串进行MD5校验的。能够直接使用,也能够封装成库后在调用,值得注意的是,须要将源码中函数定义中的static去掉。
hash:
hash算法见附件。
TCP/IP/UDP/ICMP中的checksum:
/*计算校验和*/
USHORT checksum(USHORT *buffer, int size)
{
unsigned long cksum=0;
while(size >1)
{
cksum += *buffer++;
size -= sizeof(USHORT);
}
if(size)
{
cksum += *(UCHAR*)buffer;
}
cksum = (cksum >> 16) + (cksum & 0xffff);
cksum += (cksum >> 16);
return (USHORT)(~cksum);
}
CRC校验:
int file_crc32(const char *filename, unsigned int *crc)
{
unsigned char buffer[MAX_BUFFER_SIZE];
unsigned int vcrc = 0xffffffff;
unsigned int read = 0;
unsigned int filesize = 0;
FILE *fp = NULL;
struct stat fst;
if(stat(filename, &fst))
{
printf("get file info failed\n");
return -1;
}
/* unsigned long may denote the file size */
if((filesize = fst.st_size) == 0)
return -1;
/* open file */
if((fp = fopen(filename, "r")) == NULL)
{
printf("open the file failed\n");
}
while(filesize)
{
read = filesize > MAX_BUFFER_SIZE ? MAX_BUFFER_SIZE:filesize;
if((read = fread(buffer, 1, read, fp)) == 0) break;
/* CRC */
crc32(buffer, read, &vcrc);
filesize -= read;
}
*crc = ~vcrc;
fclose(fp);
return 0;
}
void crc32(const unsigned char* byte, unsigned int length, unsigned int *vcrc)
{
unsigned int i = 0;
for(i = 0; i < length; i++)
*vcrc = ((*vcrc) >> 8) ^ crc32table[byte[i] ^ ((*vcrc) & 0x000000FF)];
}