gpt4 book ai didi

iphone - base64 中的 SHA1 和十六进制输出中的 HMAC 问题 ios iphone

转载 作者:行者123 更新时间:2023-11-28 17:42:13 24 4
gpt4 key购买 nike

我很享受在 iPhone Applecation 中实现 SHA1 和 HMAC 方法的乐趣。我需要访问一个网络服务(我无法控制),它们需要 SHA1 和 HMAC 加密。

对于 base64 中的 SHA1,我使用以下方法。

    -(NSString*)sha1ith64Base:(NSString *)stringtoencode
{
unsigned char result[CC_SHA1_DIGEST_LENGTH];
const char *cStr = [stringtoencode UTF8String];
CC_SHA1(cStr, strlen(cStr), result);
NSData *pwHashData = [[NSData alloc] initWithBytes:result length: sizeof result];
NSString *base64 = [Base64 encode:pwHashData];

NSLog(@"SHA1 in base64 %@",base64);

return base64;
}

对于我的 HMAC,我使用以下方法:

    - (NSString *) encodeWithHmacsha1:(NSString *)k0:(NSString*)m0
{
const char *cKey = [k0 cStringUsingEncoding:NSASCIIStringEncoding];
const char *cData = [m0 cStringUsingEncoding:NSASCIIStringEncoding];

unsigned char cHMAC[CC_SHA1_DIGEST_LENGTH];

CCHmac(kCCHmacAlgSHA1, cKey, strlen(cKey), cData, strlen(cData), cHMAC);

NSString *s = [NSString stringWithFormat:
@"%02X%02X%02X%02X%02X%02X%02X%02X%02X%02X%02X%02X%02X%02X%02X%02X%02X%02X%02X%02X",
cHMAC[0], cHMAC[1], cHMAC[2], cHMAC[3], cHMAC[4],
cHMAC[5], cHMAC[6], cHMAC[7],
cHMAC[8], cHMAC[9], cHMAC[10], cHMAC[11], cHMAC[12],
cHMAC[13], cHMAC[14], cHMAC[15],
cHMAC[16], cHMAC[17], cHMAC[18], cHMAC[19]
];

NSLog(@"HMAC in hex %@",s);
return s;
}

但我的实际问题是,有什么方法可以在本地测试这些方法,而不是通过网络服务 - 所以我可以排除来自 wbservice 的错误。

问候

已解决:为了测试我的实现,我使用以下方法 - 希望有一天这可以帮助某人。

    -(void)testEncryptions
{
NSString *key = @"Jefe";
NSString *data = @"what do ya want for nothing?";

NSString *digestAnswerHMAC =@"effcdf6ae5eb2fa2d27416d5f184df9c259a7c79";
NSString *digestAnswerSHA1HEX =@"cb5551f403fac5fd3d6d1b6329993c3848c468ce";

NSString *disgest64base=@"SmVmZQ==";
NSData *stringBytes = [key dataUsingEncoding: NSUTF8StringEncoding];
NSString *hash = [Base64 encode:stringBytes];
//////
NSLog(@"testing encryptions");
NSLog(@"testing HMAC encryptions is :%@ should be :%@",[self encodeWithHmacsha1:key :data],digestAnswerHMAC);
NSLog(@"testing SHA1 in HEX encryption is :%@ should be :%@",[self sha1:key],digestAnswerSHA1HEX);
NSLog(@"testing base64 is :%@ should be :%@",hash,disgest64base);
NSLog(@"testing sha1 in 64 1234 is %@ and should be cRDtpNCeBiql5KOQsKVyrA0sAiA=",[self sha1ith64Base:@"1234"]);
}

最佳答案

为了测试您的 key 散列方法,您需要建立一组已知的测试数据。这样你就知道基于一些匹配输入的预期输出是什么。 RFC2202可以得到很多不同标准的测试数据

因此,通过比较这些众所周知的数据集的一些单元测试,可以轻松地测试您的实现。

如果您想测试您是否真的将查询编码到网络服务并正确处理响应,您可以查看某种 stub 或模拟测试。同样,您需要建立一组已知的输入数据和预期输出。

一旦你有了这个引用测试集,你就可以实现一个自定义的 NSURLProtocol,它将充当真正的网络服务,但会为你提供“引用”响应。我的博客上有关于这个话题的详细描述:

关于iphone - base64 中的 SHA1 和十六进制输出中的 HMAC 问题 ios iphone,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/7710964/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com