iOS 开发 网络请求添加签名


签名算法要求:

请求参数增加、signStr,其中signTime为当前时间戳、signStr为16位随机字符串。

第一步,将所有请求参数按照参数名ASCII码从小到大排序(字典序),再使用URL键值对的格式(即key1=value1&key2=value2…)拼接成字符串stringA。

第二步,在stringA最后拼接上key得到stringSignTemp字符串,并对stringSignTemp进行MD5运算,再将得到的字符串所有字符转换为大写,得到sign值signValue。


注意: 签名算法进行签名后作为发送请求时的一个参数,

比如:发送请求时参数为NSDictionary*dict = @{ @"id" :@"10",

@"page":@"1",

@"signTime":@"1464147000",

@"signStr":@"c1bhbqiolpn6xs31"};

对参数进行签名

NSString *signStr = [xx encoingWithDic:dict   Withcharacter:@"c1bhbqiolpn6xs31"];

把返回的签名作为其中一个参数

[dict setObject:signStr forKey:@"sign"]

接下来就是用这个合成的字典进行请求数据啦!


/** *  加密url

   dataDic  要进行签名的字典

   character  随机16位数 

*/

+(NSString*)encoingWithDic:(NSMutableDictionary*)dataDic Withcharacter:(NSString*)character

{   

  //当前时间戳  

NSDate *datenow = [NSDate date];   

NSString *timeSp = [NSString stringWithFormat:@"%ld", (long)[datenow timeIntervalSince1970]]; 

  [dataDic setObject:timeSp forKey:@"signTime"];   

//随机16位数   

//NSString *randomStr = [NSString generateFradomCharacter]; 

  [dataDic setObject:character forKey:@"signStr"];   

/*请求参数按照参数名ASCII码从小到大排序*/   

NSArray *keys = [dataDic allKeys];   

//按字母顺序排序   

NSArray *sortedArray = [keys sortedArrayUsingComparator:^NSComparisonResult(id obj1, id obj2)

{        return [obj1 compare:obj2 options:NSNumericSearch]; 

  }];   

NSString *returnStr = @"";  

//拼接字符串   

for (int i=0;i<sortedArray.count;i++){

NSString *category = sortedArray[i];

if (i==0) {

returnStr =[NSString stringWithFormat:@"%@=%@",category,dataDic[category]];}else{

returnStr = [NSString stringWithFormat:@"%@&%@=%@",returnStr,category,dataDic[category]];}

     }

/*拼接上key得到stringSignTemp*/

returnStr = [NSString stringWithFormat:@"%@&key=%@",returnStr,urlKey];

/*md5加密*/

returnStr = [self bigmd5:returnStr];

}

//md5 32位加密 (大写)

+(NSString *)bigmd5:(NSString *)str {

const char *cStr = [str UTF8String];

unsigned char result[16];

CC_MD5( cStr, strlen(cStr), result );

return [NSString stringWithFormat:

@"%02X%02X%02X%02X%02X%02X%02X%02X%02X%02X%02X%02X%02X%02X%02X%02X",

result[0], result[1], result[2], result[3],

result[4], result[5], result[6], result[7],

result[8], result[9], result[10], result[11],

result[12], result[13], result[14], result[15]

];

}

//md5 32位 加密 (小写)

+ (NSString *)md5:(NSString *)str {

const char *cStr = [str UTF8String];

unsigned char result[32];

CC_MD5( cStr, strlen(cStr), result );

return [NSString stringWithFormat:

@"xxxxxxxxxxxxxxxx",

result[0],result[1],result[2],result[3],

result[4],result[5],result[6],result[7],

result[8],result[9],result[10],result[11],

result[12],result[13],result[14],result[15],

result[16], result[17],result[18], result[19],

result[20], result[21],result[22], result[23],

result[24], result[25],result[26], result[27],

result[28], result[29],result[30], result[31]];

}

//产生16位随机数

+ (NSString *)generateFradomCharacter

{

static int kNumber = 16;

NSString *sourceStr = @"abcdefghijklmnopqrstuvwxyz0123456789";

NSMutableString *resultStr = [[NSMutableString alloc] init];

for (int i = 0; i < kNumber; i++)

{

unsigned index =  arc4random() % [sourceStr length];

NSString *oneStr = [sourceStr substringWithRange:NSMakeRange(index, 1)];

[resultStr appendString:oneStr];

}

return resultStr;

}

希望对大家有用!

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • /**ios常见的几种加密方法: 普通的加密方法是讲密码进行加密后保存到用户偏好设置( [NSUserDefaul...
    彬至睢阳阅读 3,042评论 0 7
  • 1.AES加解密,给NSData添加类别 NSData+AES 添加头文件#import - (NSData *)...
    念念不忘的阅读 1,889评论 0 3
  • 首先罗列一些知识点: 1.加密算法通常分为对称性加密算法和非对称性加密算法:对于对称性加密算法,信息接收双方都需事...
    JonesCxy阅读 1,446评论 2 4
  • 我真的是一个比较容易掉链子的人,因为我累了就会歇几天,我困了就会早早睡,懒癌又犯了对不?还好今早就能够意识...
    胡敏宜阅读 352评论 0 0
  • 人生几十年,从没像今年这样,自己的星座被黑得这么惨。居然有人对我说,将来得告诉儿子,找老婆千万不能是水瓶座。 我擦...
    花咯阅读 574评论 1 0