最近在項(xiàng)目中使用到了網(wǎng)絡(luò)請求簽名認(rèn)證的方法,于是在網(wǎng)上找關(guān)于OC sha1加密
的方法上忍,很快找到了一個大眾使用的封裝好的方法骤肛,以下代碼便是
首先需要添加頭文件
#import<CommonCrypto/CommonDigest.h>
然后直接使用下面的方法就可以了
//sha1加密方式
- (NSString *) sha1:(NSString *)input
{
const char *cstr = [input cStringUsingEncoding:NSUTF8StringEncoding];
NSData *data = [NSData dataWithBytes:cstr length:input.length];
uint8_t digest[CC_SHA1_DIGEST_LENGTH];
CC_SHA1(data.bytes, (unsigned int)data.length, digest);
NSMutableString *output = [NSMutableString stringWithCapacity:CC_SHA1_DIGEST_LENGTH * 2];
for(int i=0; i<CC_SHA1_DIGEST_LENGTH; i++) {
[output appendFormat:@"%02x", digest[i]];
}
return output;
}
我直接在項(xiàng)目中使用了這個方法,而且完美解決問題窍蓝,但是,今天重點(diǎn)說的是這個但是,在后期的項(xiàng)目修改中腋颠,需要加密的字符串
里面增加了漢字(之前需要加密的字符串中無漢字),在這種情況下它抱,上面的方法就和服務(wù)器那邊的加密不一樣
了(艱難的調(diào)試排除問題的過程不贅述);
最終發(fā)現(xiàn)的原因就是我這邊生成的加密字符串和服務(wù)器
那邊生成的不一樣秕豫,自然就會發(fā)生錯誤;錯誤的原因就是因?yàn)?code>加密的字符串中包含有漢字
然后是在網(wǎng)上查找观蓄,在<[主題:如何對中文字符串進(jìn)行sha1加密][id]>這個帖子中找到了方法,現(xiàn)貢獻(xiàn)給大家
[id]:http://www.cocoachina.com/bbs/read.php?tid=263440&page=e&#a
首先需要添加頭文件
#import<CommonCrypto/CommonDigest.h>
然后直接使用下面的方法就可以了
//sha1加密方式
- (NSString *) sha1:(NSString *)input
{
//const char *cstr = [input cStringUsingEncoding:NSUTF8StringEncoding];
//NSData *data = [NSData dataWithBytes:cstr length:input.length];
NSData *data = [input dataUsingEncoding:NSUTF8StringEncoding];
uint8_t digest[CC_SHA1_DIGEST_LENGTH];
CC_SHA1(data.bytes, (unsigned int)data.length, digest);
NSMutableString *output = [NSMutableString stringWithCapacity:CC_SHA1_DIGEST_LENGTH * 2];
for(int i=0; i<CC_SHA1_DIGEST_LENGTH; i++) {
[output appendFormat:@"%02x", digest[i]];
}
return output;
}
可以看出這個方法與第一個方法的區(qū)別混移,頭兩句注釋掉了,用
NSData *data = [input dataUsingEncoding:NSUTF8StringEncoding];
代替了那兩句的作用侮穿;
帖子一樓bindbasic的原話是這樣的
用上面的方法中文字符串轉(zhuǎn)data時會造成數(shù)據(jù)丟失歌径,
把
const char *cstr = [input cStringUsingEncoding:NSUTF8StringEncoding];
NSData *data = [NSData dataWithBytes:cstr length:input.length];
這兩句改成
NSData *data = [input dataUsingEncoding:NSUTF8StringEncoding];
就可以了
經(jīng)實(shí)測,第二種方法的加密方式適用于純字符串以及帶有中文的字符串亲茅,推薦使用回铛,推薦使用,推薦使用?寺唷R鹚唷!(重要的事情說三遍)
備注:嚴(yán)格來說袭祟,sha1(安全[哈希算法])只是叫做一種算法验残,用于檢驗(yàn)數(shù)據(jù)完整性
,并不能叫做加密
~感謝2樓的指點(diǎn)