ios-MD5加密

我们都知道现在去百度搜索MD5加密是可以进行破解的,但其实这个是暴力破解或者说也就是通过一个数据库,进行查询的破解

直接使用MD5加密可以这么做 md5String函数就是进行MD5加密的函数

 passwordd = [password md5String];

防止暴力破解的问题我们尽量可以把密码设置的复杂点

加盐

就是原密码+一个复杂的字符串,防止用户输入的密码太简单。

password = [[password stringByAppendingString:@"abc123ABC!@##"] md5String];

HMAC

原密码+一个字符串 进行拼接之后再进行MD5计算,把计算的结果+原密码再进行MD5计算,这样就增加了密码的复杂性,hmacMD5StringWithKey这个函数内部就处理了这个过程,一般来说HMAC中的那个字符串其实是来自于服务器的,在注册的时候向服务器索取就可以了,然后你的这个key服务器会返回,而且会保存在本地,如果说你在别的手机登录的话其实也是有获取这个key的过程的。

password = [password hmacMD5StringWithKey:@"abc223"];

MD5+时间 每次生成的MD5的值是不一样的

我们可以这样

1、把一个字符串进行MD5计算

2、把原密码和之前生成的MD5的值再进行HMAC加密

3、从服务器获取当前时间准确的到分钟的字符串

4、把第二步得到的HMAC值+时间和第一步产生的MD5值再进行HMAC加密

- (NSString *)getPassword:(NSString *)password {
//  1  一个字符串key    md5计算
    NSString *md5Key = [@"mimi" md5String];
//  2  把原密码和之前生成的md5值再进行hmac加密
    NSString *hmacKey = [password hmacMD5StringWithKey:md5Key];
//  3  从服务器获取时间的字符串我们进简单化了直接从一个网站获取json数据然后json解析
    NSURL *url = [NSURL URLWithString:@"http://127.0.0.1"];
    NSData *data = [NSData dataWithContentsOfURL:url];
    //JSON的反序列化
    NSDictionary *dic = [NSJSONSerialization JSONObjectWithData:data options:0 error:NULL];
    NSString *time = dic[@"key"];
    
// 4   第二步产生的hmac值+时间,和第一步产生的md5值进行hmac加密
    return [[hmacKey stringByAppendingString:time] hmacMD5StringWithKey:md5Key];
}
关于MD5其实还可以运用于搜索引擎的领域以及版权的领域。因为当我们把一个文件复制粘贴的时候其实MD5值都是不一样的,虽然文件长的一模一样。

1、资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合; 4、下载使用后,可先查看README.md或论文文件(如有),本项目仅用作交流学习参考,请切勿用于商业用途。 5、资源来自互联网采集,如有侵权,私聊博主删除。 6、可私信博主看论文后选择购买源代码。 1、资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合; 4、下载使用后,可先查看README.md或论文文件(如有),本项目仅用作交流学习参考,请切勿用于商业用途。 5、资源来自互联网采集,如有侵权,私聊博主删除。 6、可私信博主看论文后选择购买源代码。 1、资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合; 4、下载使用后,可先查看README.md或论文文件(如有),本项目仅用作交流学习参考,请切勿用于商业用途。 5、资源来自互联网采集,如有侵权,私聊博主删除。 6、可私信博主看论文后选择购买源代码。
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值