科技改变生活 · 科技引领未来

  • 首页
  • 资讯
  • 技术
  • 百科
  • 问答
  • 学习
  • 看看
  • 站长
  • 生活
  • 快讯

首页 > 看看 > 创业经验

md5在线加密 md5在线加密hex

时间:2022-08-25 11:11 作者:丁楠明

本文详细讲解视频如下:

《C语言实现MD5算法》

一、摘要算法

摘要算法又称哈希算法。

它表示输入任意长度的数据,输出固定长度的数据,它的主要特征是加密过程不需要密钥,并且经过加密的数据无法被解密。

目前可以被解密逆向的只有CRC32算法,只有输入相同的明文数据经过相同的消息摘要算法才能得到相同的密文。

消息摘要算法不存在密钥的管理与分发问题,适合于分布式网络上使用。由于其加密计算的工作量相当巨大,所以以前的这种算法通常只用于数据量有限的情况下的加密。

消息摘要算法分为三类:

  • MD(Message Digest):消息摘要
  • SHA(Secure Hash Algorithm):安全散列
  • MAC(Message Authentication Code):消息认证码

这三类算法的主要作用:验证数据的完整性

二、MD5简介

MD5即Message-Digest Algorithm 5(信息-摘要算法)。

属于摘要算法,是一个不可逆过程,就是无论多大数据,经过算法运算后都是生成固定长度的数据,结果使用16进制进行显示的128bit的二进制串。通常表示为32个十六进制数连成的字符串。

MD5有什么用?

用于确保信息传输完整一致。是计算机广泛使用的杂凑算法之一(又译摘要算法、哈希算法),主流编程语言普遍已有MD5实现。更多用在文档校验上,用来生成密钥检测文档是否被篡改。

三、在线MD5加密

有很多在线进行MD5加密的网站,如下:

http://www.metools.info/code/c26.html

举例: 给字符串 12334567 加密成。

如图结果为:

32135A337F8DC8E2BB9A9B80D86BDFD0

四、C语言实现MD5算法

源文件如下:md5.h

ifndef MD5_H
define MD5_H
 
typedef struct
{
    unsigned int count[2];
    unsigned int state[4];
    unsigned char buffer[64];   
}MD5_CTX;
 
                         
define F(x,y,z) ((x & y) | (~x & z))
define G(x,y,z) ((x & z) | (y & ~z))
define H(x,y,z) (x^y^z)
define I(x,y,z) (y ^ (x | ~z))
define ROTATE_LEFt(x,n) ((x << n) | (x >> (32-n)))
define FF(a,b,c,d,x,s,ac) 
          { 
          a += F(b,c,d) + x + ac; 
          a = ROTATE_LEFt(a,s); 
          a += b; 
          }
define GG(a,b,c,d,x,s,ac) 
          { 
          a += G(b,c,d) + x + ac; 
          a = ROTATE_LEFt(a,s); 
          a += b; 
          }
define HH(a,b,c,d,x,s,ac) 
          { 
          a += H(b,c,d) + x + ac; 
          a = ROTATE_LEFt(a,s); 
          a += b; 
          }
define II(a,b,c,d,x,s,ac) 
          { 
          a += I(b,c,d) + x + ac; 
          a = ROTATE_LEFt(a,s); 
          a += b; 
          }                                            
void MD5Init(MD5_CTX *context);
void MD5Update(MD5_CTX *context,unsigned char *input,unsigned int inputlen);
void MD5Final(MD5_CTX *context,unsigned char digest[16]);
void MD5Transform(unsigned int state[4],unsigned char block[64]);
void MD5Encode(unsigned char *output,unsigned int *input,unsigned int len);
void MD5Decode(unsigned int *output,unsigned char *input,unsigned int len);
 
endif

md5.c

include 
include &34;md5.h&34;
 
unsigned char PADDING[]={0x80,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,
                         0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,
                         0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,
                         0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0};
                         
void MD5Init(MD5_CTX *context)
{
     context->count[0] = 0;
     context->count[1] = 0;
     context->state[0] = 0x67452301;
     context->state[1] = 0xEFCDAB89;
     context->state[2] = 0x98BADCFE;
     context->state[3] = 0x10325476;
}
void MD5Update(MD5_CTX *context,unsigned char *input,unsigned int inputlen)
{
    unsigned int i = 0,index = 0,partlen = 0;
    index = (context->count[0] >> 3) & 0x3F;
    partlen = 64 - index;
    context->count[0] += inputlen << 3;
    if(context->count[0] < (inputlen << 3))
       context->count[1]++;
    context->count[1] += inputlen >> 29;
    
    if(inputlen >= partlen)
    {
       memcpy(&context->buffer[index],input,partlen);
       MD5Transform(context->state,context->buffer);
       for(i = partlen;i+64 <= inputlen;i+=64)
           MD5Transform(context->state,&input[i]);
       index = 0;        
    }  
    else
    {
        i = 0;
    }
    memcpy(&context->buffer[index],&input[i],inputlen-i);
}
void MD5Final(MD5_CTX *context,unsigned char digest[16])
{
    unsigned int index = 0,padlen = 0;
    unsigned char bits[8];
    index = (context->count[0] >> 3) & 0x3F;
    padlen = (index < 56)?(56-index):(120-index);
    MD5Encode(bits,context->count,8);
    MD5Update(context,PADDING,padlen);
    MD5Update(context,bits,8);
    MD5Encode(digest,context->state,16);
}
void MD5Encode(unsigned char *output,unsigned int *input,unsigned int len)
{
    unsigned int i = 0,j = 0;
    while(j < len)
    {
         output[j] = input[i] & 0xFF;  
         output[j+1] = (input[i] >> 8) & 0xFF;
         output[j+2] = (input[i] >> 16) & 0xFF;
         output[j+3] = (input[i] >> 24) & 0xFF;
         i++;
         j+=4;
    }
}
void MD5Decode(unsigned int *output,unsigned char *input,unsigned int len)
{
     unsigned int i = 0,j = 0;
     while(j < len)
     {
           output[i] = (input[j]) |
                       (input[j+1] << 8) |
                       (input[j+2] << 16) |
                       (input[j+3] << 24);
           i++;
           j+=4; 
     }
}
void MD5Transform(unsigned int state[4],unsigned char block[64])
{
     unsigned int a = state[0];
     unsigned int b = state[1];
     unsigned int c = state[2];
     unsigned int d = state[3];
     unsigned int x[64];
     MD5Decode(x,block,64);
     FF(a, b, c, d, x[ 0], 7, 0xd76aa478); 
 FF(d, a, b, c, x[ 1], 12, 0xe8c7b756); 
 FF(c, d, a, b, x[ 2], 17, 0x242070db); 
 FF(b, c, d, a, x[ 3], 22, 0xc1bdceee); 
 FF(a, b, c, d, x[ 4], 7, 0xf57c0faf); 
 FF(d, a, b, c, x[ 5], 12, 0x4787c62a); 
 FF(c, d, a, b, x[ 6], 17, 0xa8304613); 
 FF(b, c, d, a, x[ 7], 22, 0xfd469501); 
 FF(a, b, c, d, x[ 8], 7, 0x698098d8); 
 FF(d, a, b, c, x[ 9], 12, 0x8b44f7af); 
 FF(c, d, a, b, x[10], 17, 0xffff5bb1); 
 FF(b, c, d, a, x[11], 22, 0x895cd7be); 
 FF(a, b, c, d, x[12], 7, 0x6b901122); 
 FF(d, a, b, c, x[13], 12, 0xfd987193); 
 FF(c, d, a, b, x[14], 17, 0xa679438e); 
 FF(b, c, d, a, x[15], 22, 0x49b40821); 
 
 
 GG(a, b, c, d, x[ 1], 5, 0xf61e2562); 
 GG(d, a, b, c, x[ 6], 9, 0xc040b340); 
 GG(c, d, a, b, x[11], 14, 0x265e5a51); 
 GG(b, c, d, a, x[ 0], 20, 0xe9b6c7aa); 
 GG(a, b, c, d, x[ 5], 5, 0xd62f105d); 
 GG(d, a, b, c, x[10], 9,  0x2441453); 
 GG(c, d, a, b, x[15], 14, 0xd8a1e681); 
 GG(b, c, d, a, x[ 4], 20, 0xe7d3fbc8); 
 GG(a, b, c, d, x[ 9], 5, 0x21e1cde6); 
 GG(d, a, b, c, x[14], 9, 0xc33707d6); 
 GG(c, d, a, b, x[ 3], 14, 0xf4d50d87); 
 GG(b, c, d, a, x[ 8], 20, 0x455a14ed); 
 GG(a, b, c, d, x[13], 5, 0xa9e3e905); 
 GG(d, a, b, c, x[ 2], 9, 0xfcefa3f8); 
 GG(c, d, a, b, x[ 7], 14, 0x676f02d9); 
 GG(b, c, d, a, x[12], 20, 0x8d2a4c8a); 
 
 
 HH(a, b, c, d, x[ 5], 4, 0xfffa3942); 
 HH(d, a, b, c, x[ 8], 11, 0x8771f681); 
 HH(c, d, a, b, x[11], 16, 0x6d9d6122); 
 HH(b, c, d, a, x[14], 23, 0xfde5380c); 
 HH(a, b, c, d, x[ 1], 4, 0xa4beea44); 
 HH(d, a, b, c, x[ 4], 11, 0x4bdecfa9); 
 HH(c, d, a, b, x[ 7], 16, 0xf6bb4b60); 
 HH(b, c, d, a, x[10], 23, 0xbebfbc70); 
 HH(a, b, c, d, x[13], 4, 0x289b7ec6); 
 HH(d, a, b, c, x[ 0], 11, 0xeaa127fa); 
 HH(c, d, a, b, x[ 3], 16, 0xd4ef3085); 
 HH(b, c, d, a, x[ 6], 23,  0x4881d05); 
 HH(a, b, c, d, x[ 9], 4, 0xd9d4d039); 
 HH(d, a, b, c, x[12], 11, 0xe6db99e5); 
 HH(c, d, a, b, x[15], 16, 0x1fa27cf8); 
 HH(b, c, d, a, x[ 2], 23, 0xc4ac5665); 
 
 
 II(a, b, c, d, x[ 0], 6, 0xf4292244); 
 II(d, a, b, c, x[ 7], 10, 0x432aff97); 
 II(c, d, a, b, x[14], 15, 0xab9423a7); 
 II(b, c, d, a, x[ 5], 21, 0xfc93a039); 
 II(a, b, c, d, x[12], 6, 0x655b59c3); 
 II(d, a, b, c, x[ 3], 10, 0x8f0ccc92); 
 II(c, d, a, b, x[10], 15, 0xffeff47d); 
 II(b, c, d, a, x[ 1], 21, 0x85845dd1); 
 II(a, b, c, d, x[ 8], 6, 0x6fa87e4f); 
 II(d, a, b, c, x[15], 10, 0xfe2ce6e0); 
 II(c, d, a, b, x[ 6], 15, 0xa3014314); 
 II(b, c, d, a, x[13], 21, 0x4e0811a1); 
 II(a, b, c, d, x[ 4], 6, 0xf7537e82); 
 II(d, a, b, c, x[11], 10, 0xbd3af235); 
 II(c, d, a, b, x[ 2], 15, 0x2ad7d2bb); 
 II(b, c, d, a, x[ 9], 21, 0xeb86d391); 
     state[0] += a;
     state[1] += b;
     state[2] += c;
     state[3] += d;
}

五、MD5加密实例

MD5加密步骤如下:

  1. 定义
MD5_CTX md5c; 
  1. 初始化

MD5Init(MD5_CTX *context);
  1. MD5值计算

实现MD5值的计算及结构体的更新:



MD5Update(MD5_CTX *context,(unsigned char *)input,inputLen); 
  1. 输出转换

MD5Final(MD5_CTX *context,unsigned char digest[16]);
  1. 格式整理

转换成32位的16进制字符串。

实例1 字符串加密

对字符串进行加密:

  1 include 
  2 include 
  3 include &34;md5.h&34;
  4 include 
  5 include 
  6 include 
  7 include 
  8 
  9 void main( void ) 
 10 { 
 11     int read_len;
 12     int i ;
 13     char temp[8]={0};
 14     unsigned char digest[16]; //存放结果 
 15     char hexbuf[128]=&34;12334567&34;;
 16     unsigned char decrypt[16]={0};  
 17     unsigned char decrypt32[64]={0};    
 18 
 19     MD5_CTX md5c; 
 20 
 21     MD5Init(&md5c); //初始化
 22     read_len = strlen(hexbuf);
 23     MD5Update(&md5c,(unsigned char *)hexbuf,read_len);  
 24 
 25     MD5Final(&md5c,decrypt); 
 26     strcpy((char *)decrypt32,&34;&34;);
 27 
 28     for(i=0;i<16;i++)
 29     {
 30         sprintf(temp,&34;%02x&34;,decrypt[i]);
 31         strcat((char *)decrypt32,temp);
 32     }
 33     printf(&34;md5:%sn&34;,decrypt32);
 34     
 35     return;
 36 }

执行结果如下:

本例对字符串12334567进行加密,结果和在线加密结果一致。

实例2 文件加密

对文件进行加密

include 
include 
include &34;md5.h&34;
include 
include 
include 
include 

define FORWORD_FW &34;123.c&34;

int calc_md5(char*filename,char*dest)
{
 int i;
 int filelen = 0;
 int read_len;
 char temp[8]={0}; 
 char hexbuf[128]={0};
 unsigned char decrypt[16]={0};  
 unsigned char decrypt32[64]={0};
 MD5_CTX md5;
 char fw_path[128];

 int fdf;
 
 fdf = open(filename,O_RDWR);
 if(fdf<0)
 {
  printf(&34;%s not existn&34;,FORWORD_FW);
  return -1;
 }
 
 MD5Init(&md5);  
 while(1)
 {
  read_len = read(fdf, hexbuf,sizeof(hexbuf)); 
  if (read_len <0) {  
   close(fdf);   
   return -1;
  }
  if(read_len==0)
  {
   break;
  }
  filelen += read_len;
  MD5Update(&md5,(unsigned char *)hexbuf,read_len); 
 }

 
 MD5Final(&md5,decrypt); 
 strcpy((char *)decrypt32,&34;&34;);
 
 for(i=0;i<16;i++)
 {
  sprintf(temp,&34;%02x&34;,decrypt[i]);
  strcat((char *)decrypt32,temp);
 }
 strcpy(dest,decrypt32);

 printf(&34;md5:%s len=%dn&34;,dest,filelen);
 close(fdf);

 return filelen;
}
int main(int argc, char *argv[])
{
 int ret;
 int filelen;
 char md5_str[64]={0};
 char cmd[256]={0};
 
 filelen = calc_md5(FORWORD_FW,md5_str);
 if(filelen<0)
 {
  printf(&34;calc_md5 failn&34;);
  return -1;
 }

 return 0;
}

运行结果:

在线验证结果对比:

http://www.metools.info/other/o21.html

结果

相关话题

  • 蜘蛛胶多少钱一斤(硬核解答)
  • 男性检查生育多少钱(很多人有可能不知道这些关于生育保险的知识)
  • 2009年茅台53度多少钱一瓶(鉴别小技巧)
  • 全身体检一次大概多少钱(PET)
  • 铝回收价格多少钱一斤(最新2月12日废铝价格汇总)
  • 医院打b超需要多少钱(B超)
  • 装修北欧风格多少钱(花了8)
  • 手表的表带一般多少钱(你的身份)
  • 风力发电机组多少钱一台(为何风力发电会遭强烈抵制)
  • 种植一根头发要多少钱(35岁就)
  • 修水龙头一般多少钱(为何有人说)
  • 处女膜补一次多少钱(每个人都有处女膜吗)
  • 衣柜价格多少钱一平方(定制柜子一般多少钱一平米)
  • 华为aicamera多少钱(ivvi)
  • 西麦燕麦片多少钱一袋(10款燕麦片对比测评)
  • 黑鲨手机多少钱(黑鲨)
  • 考雅思大概要花多少钱(雅思考试一次需要多少钱)
  • 二十文铜币值多少钱(最新四川铜币当二十文价格)
  • 莫桑钻石多少钱一克拉(专骗中国人)
  • 康复新液价格多少钱一瓶(小康说药)

热门推荐

  • 古钟二锅头46度多少钱(全国喝啥酒)
  • 顺丰寄50斤冰箱多少钱(评测五大快递平台)
  • 做饭保姆一个月多少钱(52岁阿姨哭诉)
  • 鹿茸补肾丸多少钱一盒(参茸鞭丸肾阴虚者能吃吗)
  • 北京换烤瓷牙多少钱(明星为整牙有多拼)
  • 乐高培训加盟费多少钱(乐高教育取消授权波及上百门店)
  • 西凤酒15年多少钱一瓶(价不高待客又不失面子的纯粮酒)
  • 聚酰亚胺多少钱一公斤(酶中战斗机)
  • 公司入职体检一般多少钱(通过聘多多找到工作)
  • 插座维修上门多少钱(换个插座还用找电工)
  • 二元店一年挣多少钱(揭秘)
  • ctfau750钻戒多少钱(黑客游戏和解谜游戏的关联之处)
  • 23年工龄退休拿多少钱(缴费23年)
  • 平衡霜多少钱一瓶(日本POLA旗下这个小众牌子THREE)
  • 欧米茄手表电池多少钱一块(福布斯公布运动员收入榜单)
  • 正规医院种植牙多少钱一颗(成本百元却卖上万)
  • 微信能卖多少钱(微信账号被公开买卖)
  • 奔富707多少钱一瓶(宴请时的)
  • 超声波焊接机多少钱一台(关于超声波焊接)
  • 一鸣加盟费要多少钱(一鸣真鲜奶吧多少钱)

丁楠明

关注
免责声明:本文章由会员“丁楠明”发布,如果文章侵权,请联系我们处理,本站仅提供信息存储空间服务 如因作品内容、版权和其他问题请于本站联系

关注排行榜

  1. 1新百伦多少钱(都有一个)
  2. 2活牛多少钱一斤(牛价丨2月11日)
  3. 3铝单板多少钱一平方(铝单板厂家报价大揭秘)
  4. 4一箱牛奶多少钱(实体店一箱牛奶卖50元)
  5. 5普洱茶一般多少钱(有的普洱茶只要几十有的上万)
  6. 6换手机外屏多少钱(盘点各个旗舰手机换屏价格)
  7. 7一辆电动车多少钱(最低不到8000元)
  8. 8巴宝莉围巾多少钱(花2580元网购的博柏利围巾竟系假货)
  9. 9养老保险每年多少钱(2021年养老保险缴费15年)
  10. 10每升油多少钱(​定了)

编辑精选

Copyright ©2009-2022 KeJiTian.Com, All Rights Reserved

版权所有 未经许可不得转载

增值电信业务经营许可证备案号:辽ICP备14006349号

网站介绍 商务合作 免责声明 - html - txt - xml