alghmac.c

来自「支持SSL v2/v3, TLS, PKCS #5, PKCS #7, PKCS」· C语言 代码 · 共 170 行

C
170
字号
/* * The contents of this file are subject to the Mozilla Public * License Version 1.1 (the "License"); you may not use this file * except in compliance with the License. You may obtain a copy of * the License at http://www.mozilla.org/MPL/ *  * Software distributed under the License is distributed on an "AS * IS" basis, WITHOUT WARRANTY OF ANY KIND, either express or * implied. See the License for the specific language governing * rights and limitations under the License. *  * The Original Code is the Netscape security libraries. *  * The Initial Developer of the Original Code is Netscape * Communications Corporation.  Portions created by Netscape are  * Copyright (C) 1994-2000 Netscape Communications Corporation.  All * Rights Reserved. *  * Contributor(s): *  * Alternatively, the contents of this file may be used under the * terms of the GNU General Public License Version 2 or later (the * "GPL"), in which case the provisions of the GPL are applicable  * instead of those above.  If you wish to allow use of your  * version of this file only under the terms of the GPL and not to * allow others to use your version of this file under the MPL, * indicate your decision by deleting the provisions above and * replace them with the notice and other provisions required by * the GPL.  If you do not delete the provisions above, a recipient * may use your version of this file under either the MPL or the * GPL. */#include "alghmac.h"#include "sechash.h"#include "secoid.h"#include "secport.h"#define HMAC_PAD_SIZE 64struct HMACContextStr {    void *hash;    SECHashObject *hashobj;    unsigned char ipad[HMAC_PAD_SIZE];    unsigned char opad[HMAC_PAD_SIZE];};voidHMAC_Destroy(HMACContext *cx){    if (cx == NULL)	return;    if (cx->hash != NULL)	cx->hashobj->destroy(cx->hash, PR_TRUE);    PORT_ZFree(cx, sizeof(HMACContext));}HMACContext *HMAC_Create(SECOidTag      hash_alg,       const unsigned char *secret,             unsigned int   secret_len){    HMACContext *cx;    int i;    unsigned char hashed_secret[SHA1_LENGTH];    cx = (HMACContext*)PORT_ZAlloc(sizeof(HMACContext));    if (cx == NULL)	return NULL;    switch (hash_alg) {      case SEC_OID_MD5:	cx->hashobj = &SECRawHashObjects[HASH_AlgMD5];	break;      case SEC_OID_MD2:	cx->hashobj = &SECRawHashObjects[HASH_AlgMD2];	break;      case SEC_OID_SHA1:	cx->hashobj = &SECRawHashObjects[HASH_AlgSHA1];	break;      default:	goto loser;    }    cx->hash = cx->hashobj->create();    if (cx->hash == NULL)	goto loser;    if (secret_len > HMAC_PAD_SIZE) {	cx->hashobj->begin( cx->hash);	cx->hashobj->update(cx->hash, secret, secret_len);	cx->hashobj->end(   cx->hash, hashed_secret, &secret_len, 	                 sizeof hashed_secret);	if (secret_len != cx->hashobj->length)	    goto loser;	secret = (const unsigned char *)&hashed_secret[0];    }    PORT_Memset(cx->ipad, 0x36, sizeof cx->ipad);    PORT_Memset(cx->opad, 0x5c, sizeof cx->opad);    /* fold secret into padding */    for (i = 0; i < secret_len; i++) {	cx->ipad[i] ^= secret[i];	cx->opad[i] ^= secret[i];    }    PORT_Memset(hashed_secret, 0, sizeof hashed_secret);    return cx;loser:    PORT_Memset(hashed_secret, 0, sizeof hashed_secret);    HMAC_Destroy(cx);    return NULL;}voidHMAC_Begin(HMACContext *cx){    /* start inner hash */    cx->hashobj->begin(cx->hash);    cx->hashobj->update(cx->hash, cx->ipad, sizeof(cx->ipad));}voidHMAC_Update(HMACContext *cx, const unsigned char *data, unsigned int data_len){    cx->hashobj->update(cx->hash, data, data_len);}SECStatusHMAC_Finish(HMACContext *cx, unsigned char *result, unsigned int *result_len,	    unsigned int max_result_len){    if (max_result_len < cx->hashobj->length)	return SECFailure;    cx->hashobj->end(cx->hash, result, result_len, max_result_len);    if (*result_len != cx->hashobj->length)	return SECFailure;    cx->hashobj->begin(cx->hash);    cx->hashobj->update(cx->hash, cx->opad, sizeof(cx->opad));    cx->hashobj->update(cx->hash, result, *result_len);    cx->hashobj->end(cx->hash, result, result_len, max_result_len);    return SECSuccess;}HMACContext *HMAC_Clone(HMACContext *cx){    HMACContext *newcx;    newcx = (HMACContext*)PORT_ZAlloc(sizeof(HMACContext));    if (newcx == NULL)	goto loser;    newcx->hashobj = cx->hashobj;    newcx->hash = cx->hashobj->clone(cx->hash);    if (newcx->hash == NULL)	goto loser;    PORT_Memcpy(newcx->ipad, cx->ipad, sizeof(cx->ipad));    PORT_Memcpy(newcx->opad, cx->opad, sizeof(cx->opad));    return newcx;loser:    HMAC_Destroy(newcx);    return NULL;}

⌨️ 快捷键说明

复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?