很有用,现在很多微博在认证的时候都会用到,OAUTH的协议详见http://oauth.net/documentation/getting-started/
那在iPhone SDK中如何使用HMAC-SHA1计算呢?
Key一般是指的secret串,text是base串。
key是两个secret串用&连接起来的,比如说新浪微博,申请application时会得到一个api key和secret,获取request token的时候又获得了一个token secret。
在获取access token的时候,key就是secret&token_secret.
引入头文件
#import <CommonCrypto/CommonHMAC.h>
#import <CommonCrypto/CommonCryptor.h>
+ (NSString *)hmac_sha1:(NSString *)key text:(NSString *)text{
const char *cKey = [key cStringUsingEncoding:NSUTF8StringEncoding];
const char *cData = [text cStringUsingEncoding:NSUTF8StringEncoding];
char cHMAC[CC_SHA1_DIGEST_LENGTH];
CCHmac(kCCHmacAlgSHA1, cKey, strlen(cKey), cData, strlen(cData), cHMAC);
NSData *HMAC = [[NSData alloc] initWithBytes:cHMAC length:CC_SHA1_DIGEST_LENGTH];
NSString *hash = [Base64 stringByEncodingData:HMAC];//base64 编码。
[HMAC release];
return hash;
}
那在iPhone SDK中如何使用HMAC-SHA1计算呢?
Key一般是指的secret串,text是base串。
key是两个secret串用&连接起来的,比如说新浪微博,申请application时会得到一个api key和secret,获取request token的时候又获得了一个token secret。
在获取access token的时候,key就是secret&token_secret.
引入头文件
#import <CommonCrypto/CommonHMAC.h>
#import <CommonCrypto/CommonCryptor.h>
+ (NSString *)hmac_sha1:(NSString *)key text:(NSString *)text{
const char *cKey = [key cStringUsingEncoding:NSUTF8StringEncoding];
const char *cData = [text cStringUsingEncoding:NSUTF8StringEncoding];
char cHMAC[CC_SHA1_DIGEST_LENGTH];
CCHmac(kCCHmacAlgSHA1, cKey, strlen(cKey), cData, strlen(cData), cHMAC);
NSData *HMAC = [[NSData alloc] initWithBytes:cHMAC length:CC_SHA1_DIGEST_LENGTH];
NSString *hash = [Base64 stringByEncodingData:HMAC];//base64 编码。
[HMAC release];
return hash;
}