本文主要是介绍iOS中 DES加解密详解 (中文韩文字符加密丢失情况),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
目前在项目当中使用到DES加解密,遇到一些问题,进行梳理,分享一下。DES和3DES加解密的原理谷歌百度都有详细的解码,这里就不赘述了。
1.DES加解密参数类型问题:
目前项目使用DES加解密都是针对字符串使用,要对一个NSDictionary类型进行加解密,需要转换成json字符串进行加解密:
使用convertToJSONData把NSDictionary转成json string进行加解密;dictionaryWithJsonString进行json转化NSdictionary数据。
+ (NSString*)convertToJSONData:(id)infoDict {NSError *error;NSData *jsonData = [NSJSONSerialization dataWithJSONObject:infoDict options:NSJSONWritingPrettyPrinted error:&error];NSString *jsonString = @"";if (! jsonData) {NSLog(@"Got an error: %@", error);} else {jsonString = [[NSString alloc] initWithData:jsonData encoding:NSUTF8StringEncoding];}jsonString = [jsonString stringByTrimmingCharactersInSet:[NSCharacterSet whitespaceAndNewlineCharacterSet]];[jsonString stringByReplacingOccurrencesOfString:@"\n" withString:@""];return jsonString;
}
+ (NSDictionary *)dictionaryWithJsonString:(NSString *)jsonString {if (jsonString == nil) {return nil;}NSData *jsonData = [jsonString dataUsingEncoding:NSUTF8StringEncoding];NSError *err;NSDictionary *dic = [NSJSONSerialization JSONObjectWithData:jsonData options:NSJSONReadingMutableContainers error:&err];if (err) {NSLog(@"json解析失败:%@",err);return nil;}return dic;
}
2.DES加解密iV和填充方式:
在开发过程中,基本上碰到的问题就是iOS端和服务器、安卓java端的加解密不匹配问题。在加解密之前应和服务端安卓端商定DES加解密过程中的iV向量和填充方式。iV向量一般取8位,对于iOS来说无论采用PKCS7Padding还是PKCS5Padding的填充方式,iv的位数不影响,对于安卓java来说采用PKCS7、PKCS5 iv一般不超过8位,综合起来,iv取8位。项目进行过程中一定要商量好iv的取值和填充方式。
目前博主采用的方式如下:对key(字符串格式,一般由服务器下发),先采用MD5,再取其MD5值的前八位作为iv:(源码文后上传)
NSString *md5Str = [key MD5];
NSString *keyString = [md5Str substringToIndex:8];
采用PKCS7Padding作为填充方式。
这篇关于iOS中 DES加解密详解 (中文韩文字符加密丢失情况)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!