iOS MD5加密

在使用之前,这里先对MD5进行一些简单的介绍,以供大家了解:

1.MD5加密全称是Message Digest Algorithm 5,译为“消息摘要算法第5版”

        1.1MD5加密是最常用的加密方法之一,是从一段字符串中通过相应特征生成一段32位的数字字母混合码。对输入信息生成唯一的128位散列值(32个字符)。

        1.2MD5生成的是固定的128bit,即128个0和1的二进制位,而在实际应用开发中,通常是以16进制输出的,所以正好就是32位的16进制,说白了也就是32个16进制的数字。

        1.3MD5主要特点是 不可逆,相同数据的MD5值肯定一样,不同数据的MD5值不一样(也不是绝对的,但基本是不能一样的)。

2.MD5算法还具有以下性质:

        2.1压缩性:任意长度的数据,算出的MD5值长度都是固定的。

        2.2容易计算:从原数据计算出MD5值很容易。

        2.3抗修改性:对原数据进行任何改动,哪怕只修改1个字节,所得到的MD5值都有很大区别。

        2.4强抗碰撞:想找到两个不同的数据,使它们具有相同的MD5值,是非常困难的。

        2.5MD5加密是不可解密的,但是网上有一些解析MD5的,那个相当于一个大型的数据库,通过匹配MD5去找到原密码。所以,只要在要加密的字符串前面加上一些字母数字符号或者多次MD5加密,这样出来的结果一般是解析不出来的。

3.MD5的应用:

        3.1由于MD5加密算法具有较好的安全性,而且免费,因此该加密算法被广泛使用

        3.2大多数的登录功能向后台提交密码时都会使用到这种算法

        3.3具体开发中可能常常会与base64混合使用

4.MD5注意点:

        4.1一定要和后台开发人员约定好,MD5加密的位数是16位还是32位(大多数都是32位的),16位的可以通过32位的转换得到。

        4.2MD5加密区分 大小写,使用时要和后台约定好。

5.具体使用:

       在iOS中使用MD5加密较简单,需要引入头文件CommonCrypto/CommonDigest.h,我们单独新建一个用于MD5加密的类Encryption,此类继承NSObject。为了让MD5码更加安全 涌现了很多其他方法 如加盐。 盐要足够长足够乱 得到的MD5码就很难查到。
Encryption.h文件如下:

#import <Foundation/Foundation.h>

@interface Encryption : NSObject
// 32位小写
+(NSString *)MD5ForLower32BateEncryptWithString:(NSString *)str;
// 32位大写
+(NSString *)MD5ForUpper32BateEncryptWithString:(NSString *)str;
// 16为大写
+(NSString *)MD5ForUpper16BateEncryptWithString:(NSString *)str;
// 16位小写
+(NSString *)MD5ForLower16BateEncryptWithString:(NSString *)str;

Encryption.m文件如下:
#import "Encryption.h"
#import <CommonCrypto/CommonDigest.h>

//秘钥
static NSString *encryptionKey = @"nha735n197nxn(N′568GGS%d~~9naei';45vhhafdjkv]32rpks;lg,];:vjo(&**&^)";

@implementation Encryption

+ (NSString *)MD5ForLower32BateEncryptWithString:(NSString *)str{
    return [self MD5ForLower32Bate:[NSString stringWithFormat:@"%@%@", encryptionKey, string]];
}
+ (NSString *)MD5ForUpper32BateEncryptWithString:(NSString *)str{
    return [self MD5ForUpper32Bate:[NSString stringWithFormat:@"%@%@", encryptionKey, string]];
}

+ (NSString *)MD5ForUpper16BateEncryptWithString:(NSString *)str{
    return [self MD5ForUpper16Bate:[NSString stringWithFormat:@"%@%@", encryptionKey, string]];
}

+ (NSString *)MD5ForLower16BateEncryptWithString:(NSString *)str{
    return [self MD5ForLower16Bate:[NSString stringWithFormat:@"%@%@", encryptionKey, string]];
}
#pragma mark - 32位 小写
+(NSString *)MD5ForLower32Bate:(NSString *)str{
    
    //要进行UTF8的转码
    const char* input = [str UTF8String];
    unsigned char result[CC_MD5_DIGEST_LENGTH];
    CC_MD5(input, (CC_LONG)strlen(input), result);
    
    NSMutableString *digest = [NSMutableString stringWithCapacity:CC_MD5_DIGEST_LENGTH * 2];
    for (NSInteger i = 0; i < CC_MD5_DIGEST_LENGTH; i++) {
        [digest appendFormat:@"%02x", result[i]];
    }
    
    return digest;
}

#pragma mark - 32位 大写
+(NSString *)MD5ForUpper32Bate:(NSString *)str{
    
    //要进行UTF8的转码
    const char* input = [str UTF8String];
    unsigned char result[CC_MD5_DIGEST_LENGTH];
    CC_MD5(input, (CC_LONG)strlen(input), result);
    
    NSMutableString *digest = [NSMutableString stringWithCapacity:CC_MD5_DIGEST_LENGTH * 2];
    for (NSInteger i = 0; i < CC_MD5_DIGEST_LENGTH; i++) {
        [digest appendFormat:@"%02X", result[i]];
    }
    
    return digest;
}

#pragma mark - 16位 大写
+(NSString *)MD5ForUpper16Bate:(NSString *)str{
    
    NSString *md5Str = [self MD5ForUpper32Bate:str];
    
    NSString  *string;
    for (int i=0; i<24; i++) {
        string=[md5Str substringWithRange:NSMakeRange(8, 16)];
    }
    return string;
}


#pragma mark - 16位 小写
+(NSString *)MD5ForLower16Bate:(NSString *)str{
    
    NSString *md5Str = [self MD5ForLower32Bate:str];
    
    NSString  *string;
    for (int i=0; i<24; i++) {
        string=[md5Str substringWithRange:NSMakeRange(8, 16)];
    }
    return string;
}

6.使用时注意:
       在实际工程中,我们不会把 Encryption.m中的秘钥暴露出来,因此实际工程中需要把 Encryption类打包成静态库,只暴露 .h文件用于使用。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值