C++ MD5,SHA1调用

最近在写c++ websocket 通信,sha1算法从网上 转的一份发现待hash字符串长度大于50左右会和网上的hash不一样,随后使用 openssl 库做运算,现在附上两种代码:

1. 网上找的算法

转自: https://www.cnblogs.com/ytjjyy/archive/2012/05/07/2487141.html

#include <iostream>
#include "../src/utility/md5.h"

void main()
{
    
    SHA1 sha1;
    
    char buffer[41];

    sha1.SHA_GO("a",buffer);

    printf("%s",buffer);

    //sha1调用
//===================================================
    //MD5调用
    std::string str = "abc";
    
    MD5 md5(str);
    
    std::string result = md5.md5();

    printf("%s",result.c_str());

    system("pause");

}

下载地址: http://files.cnblogs.com/ytjjyy/sha1-md5.zip


2. openssl库

安装: yum install openssl openssl-devel -y
编译 g++ main.cpp -lssl

#include <iostream>
#include <string.h>
#include <openssl/sha.h>
#include <openssl/crypto.h>  // OPENSSL_cleanse  

using namespace std;

const char *orgStr = "BoEnGhnXNhe0YC+7loQD6Q==258EAFA5-E914-47DA-95CA-C5AB0DC85B11"; //待哈希的串

// 打印前, 有必要转换
void printHash(unsigned char *md, int len)
{
    int i = 0;
    for (i = 0; i < len; i++)
    {
        printf("%02x", md[i]);
    }

    printf("\n");
}

void myHash1()
{
    SHA_CTX c;
    unsigned char md[SHA_DIGEST_LENGTH];
    SHA1((unsigned char *)orgStr, strlen(orgStr), md);
    printHash(md, SHA_DIGEST_LENGTH);

    SHA1_Init(&c);
    SHA1_Update(&c, orgStr, strlen(orgStr));
    SHA1_Final(md, &c);
    OPENSSL_cleanse(&c, sizeof(c));
    printHash(md, SHA_DIGEST_LENGTH);
}

void myHash224()
{
    SHA256_CTX c;
    unsigned char md[SHA224_DIGEST_LENGTH];
    SHA224((unsigned char *)orgStr, strlen(orgStr), md);
    printHash(md, SHA224_DIGEST_LENGTH);
void myHash256()
{
    SHA256_CTX c;
    unsigned char md[SHA256_DIGEST_LENGTH];
    SHA256((unsigned char *)orgStr, strlen(orgStr), md);
    printHash(md, SHA256_DIGEST_LENGTH);

    SHA256_Init(&c);
    SHA256_Update(&c, orgStr, strlen(orgStr));
    SHA256_Final(md, &c);
    OPENSSL_cleanse(&c, sizeof(c));
    printHash(md, SHA256_DIGEST_LENGTH);
}

void myHash384()
{
    SHA512_CTX c;
    unsigned char md[SHA384_DIGEST_LENGTH];
    SHA384((unsigned char *)orgStr, strlen(orgStr), md);
    printHash(md, SHA384_DIGEST_LENGTH);

    SHA384_Init(&c);
    SHA384_Update(&c, orgStr, strlen(orgStr));
    SHA384_Final(md, &c);
    OPENSSL_cleanse(&c, sizeof(c));
    printHash(md, SHA384_DIGEST_LENGTH);
}

void myHash512()
{
    SHA512_CTX c;
    unsigned char md[SHA512_DIGEST_LENGTH];
    SHA512((unsigned char *)orgStr, strlen(orgStr), md);
    printHash(md, SHA512_DIGEST_LENGTH);

    SHA512_Init(&c);
    SHA512_Update(&c, orgStr, strlen(orgStr));
    SHA512_Final(md, &c);
    OPENSSL_cleanse(&c, sizeof(c));
    printHash(md, SHA512_DIGEST_LENGTH);
}
int main()
{
    myHash1();
    myHash224();
    myHash256();
    myHash384();
    myHash512();

    return 0;
}


  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值