如何将十六进制字符串提供给 Hmac SHA256 objective C?
How to give hex string to Hmac SHA256 objective C?
我正在尝试通过以下方式在 objective C 中生成 hmac SHA256:
const char *cKey = [key cStringUsingEncoding:NSUTF8StringEncoding];
const char *cData = [data cStringUsingEncoding:NSUTF8StringEncoding];
unsigned char cHMAC[CC_SHA256_DIGEST_LENGTH];
CCHmac(kCCHmacAlgSHA256, cKey, strlen(cKey), cData, strlen(cData), cHMAC);
只要 key 是一个字符串就可以正常工作。问题出在用于生成 mac 的外部服务器命令上:
openssl dgst -binary -sha256 -mac HMAC -macopt hexkey:$key
将生成的 hmac 视为密钥 hexkey 。所以很明显 hmac 生成的是不同的。
如何让 objective C 中的 CCMac 函数将密钥视为十六进制密钥?我已经尝试将字符串键转换为字节数组并将其传递给 CCMAC,但仍然没有用。
在 android 中,我通过将十六进制数字转换为大整数然后对其执行 getBytes 来实现相同的目的,使用它来创建密钥。
希望你们中的一些人能够指导我。
这是您要找的吗?
- (NSData *)dataFromHexString:(NSString *)sHex {
const char *chars = [sHex UTF8String];
int i = 0;
NSUInteger len = sHex.length;
NSMutableData *data = [NSMutableData dataWithCapacity:len / 2];
char byteChars[3] = {'[=10=]','[=10=]','[=10=]'};
unsigned long wholeByte;
while (i < len) {
byteChars[0] = chars[i++];
byteChars[1] = chars[i++];
wholeByte = strtoul(byteChars, NULL, 16);
[data appendBytes:&wholeByte length:1];
}
return data;
}
- (NSData *)hmacForHexKey:(NSString *)hexkey andStringData:(NSString *)data
{
NSData *keyData = [self dataFromHexString:hexkey];
const char *cKey = [keyData bytes];
const char *cData = [data cStringUsingEncoding:NSUTF8StringEncoding];
unsigned char cHMAC[CC_SHA256_DIGEST_LENGTH];
CCHmac(kCCHmacAlgSHA256, cKey, keyData.length, cData, strlen(cData), cHMAC);
return [[NSData alloc] initWithBytes:cHMAC length:sizeof(cHMAC)];
}
- (NSData *)hmacForKey:(NSString *)key andStringData:(NSString *)data
{
const char *cKey = [key cStringUsingEncoding:NSUTF8StringEncoding];
const char *cData = [data cStringUsingEncoding:NSUTF8StringEncoding];
unsigned char cHMAC[CC_SHA256_DIGEST_LENGTH];
CCHmac(kCCHmacAlgSHA256, cKey, strlen(cKey), cData, strlen(cData), cHMAC);
return [[NSData alloc] initWithBytes:cHMAC length:sizeof(cHMAC)];
}
- (void)testIt {
NSString *key = @"This is my random key.";
NSString *hexKey = @"54686973206973206d792072616e646f6d206b65792e";
NSString *data = @"This is a data string.";
NSData *hmac1 = [self hmacForKey:key andStringData:data];
NSLog(@"hmacForKey : %@", hmac1);
NSData *hmac2 = [self hmacForHexKey:hexKey andStringData:data];
NSLog(@"hmacForHexKey: %@", hmac2);
}
我正在尝试通过以下方式在 objective C 中生成 hmac SHA256:
const char *cKey = [key cStringUsingEncoding:NSUTF8StringEncoding];
const char *cData = [data cStringUsingEncoding:NSUTF8StringEncoding];
unsigned char cHMAC[CC_SHA256_DIGEST_LENGTH];
CCHmac(kCCHmacAlgSHA256, cKey, strlen(cKey), cData, strlen(cData), cHMAC);
只要 key 是一个字符串就可以正常工作。问题出在用于生成 mac 的外部服务器命令上:
openssl dgst -binary -sha256 -mac HMAC -macopt hexkey:$key
将生成的 hmac 视为密钥 hexkey 。所以很明显 hmac 生成的是不同的。
如何让 objective C 中的 CCMac 函数将密钥视为十六进制密钥?我已经尝试将字符串键转换为字节数组并将其传递给 CCMAC,但仍然没有用。
在 android 中,我通过将十六进制数字转换为大整数然后对其执行 getBytes 来实现相同的目的,使用它来创建密钥。 希望你们中的一些人能够指导我。
这是您要找的吗?
- (NSData *)dataFromHexString:(NSString *)sHex {
const char *chars = [sHex UTF8String];
int i = 0;
NSUInteger len = sHex.length;
NSMutableData *data = [NSMutableData dataWithCapacity:len / 2];
char byteChars[3] = {'[=10=]','[=10=]','[=10=]'};
unsigned long wholeByte;
while (i < len) {
byteChars[0] = chars[i++];
byteChars[1] = chars[i++];
wholeByte = strtoul(byteChars, NULL, 16);
[data appendBytes:&wholeByte length:1];
}
return data;
}
- (NSData *)hmacForHexKey:(NSString *)hexkey andStringData:(NSString *)data
{
NSData *keyData = [self dataFromHexString:hexkey];
const char *cKey = [keyData bytes];
const char *cData = [data cStringUsingEncoding:NSUTF8StringEncoding];
unsigned char cHMAC[CC_SHA256_DIGEST_LENGTH];
CCHmac(kCCHmacAlgSHA256, cKey, keyData.length, cData, strlen(cData), cHMAC);
return [[NSData alloc] initWithBytes:cHMAC length:sizeof(cHMAC)];
}
- (NSData *)hmacForKey:(NSString *)key andStringData:(NSString *)data
{
const char *cKey = [key cStringUsingEncoding:NSUTF8StringEncoding];
const char *cData = [data cStringUsingEncoding:NSUTF8StringEncoding];
unsigned char cHMAC[CC_SHA256_DIGEST_LENGTH];
CCHmac(kCCHmacAlgSHA256, cKey, strlen(cKey), cData, strlen(cData), cHMAC);
return [[NSData alloc] initWithBytes:cHMAC length:sizeof(cHMAC)];
}
- (void)testIt {
NSString *key = @"This is my random key.";
NSString *hexKey = @"54686973206973206d792072616e646f6d206b65792e";
NSString *data = @"This is a data string.";
NSData *hmac1 = [self hmacForKey:key andStringData:data];
NSLog(@"hmacForKey : %@", hmac1);
NSData *hmac2 = [self hmacForHexKey:hexKey andStringData:data];
NSLog(@"hmacForHexKey: %@", hmac2);
}