iOS 自定义加密算法

开发中除了常见的RSA加密、MD5加密等,可以实现自动以算法配合加密方法使用,代码如下:

// 自定义加密算法
+ (NSString *)archlyEncryptionAlgorithmWithData:(NSString *)data key:(NSString *)key isDecode:(BOOL)isDecode{
    int len = 128;
    
    if (key == nil || key.length == 0) {
        key = @"";
    }
    
    if (data.length < 1) {
        return @"";
    }
    
    NSString *md5Key = [key md5Hash];
    NSString *keyA = [[md5Key substringToIndex:16] md5Hash];
    NSString *keyB = [[md5Key substringFromIndex:16] md5Hash];
    NSString *keyC;
    if (isDecode == YES) { // 解密
        keyC = [data substringToIndex:4];
    }else{ // 加密
        NSString *nowTime = [self getNowTimeTimestampms];
        NSString *md5Time = [nowTime md5Hash];
        keyC = [md5Time substringFromIndex:md5Time.length - 4];
    }
    NSString *cryptkey = [NSString stringWithFormat:@"%@%@",keyA,[[NSString stringWithFormat:@"%@%@",keyA,keyC] md5Hash]];
    NSInteger cryptkeyLength = cryptkey.length;
    NSString *newData;
    if (isDecode == YES) { // 解密
        NSString *preparStr = [data substringFromIndex:4];
        if (preparStr.length % 4 != 0) {
            NSInteger coverLength = 4 - preparStr.length % 4;
                    for (int i = 0; i < coverLength ; i ++) {
                        preparStr = [preparStr stringByAppendingString:@"="];
                    }
        }
        newData = [preparStr base64Dencode];
        
    }else{ // 加密
        NSString *sub = [[[NSString stringWithFormat:@"%@%@",data,keyB] md5Hash] substringToIndex:16];
        newData = [NSString stringWithFormat:@"0000000000%@%@",sub,data];
    }
    NSString *result = @"";
    NSMutableArray *box = [NSMutableArray array];
    for (int i = 0; i < len; i++) {
        [box addObject:@(i)];
    }
    
    NSMutableArray *rndkArray = [NSMutableArray array];
    for (int i = 0; i < len; i ++) {
         unichar c =  [cryptkey characterAtIndex:i % cryptkeyLength];
        [rndkArray addObject:@([self ascIIToNumber:[NSString stringWithFormat:@"%C",c]])];
    }
    int j1 = 0;
    for (int i = 0; i < len; i ++) {
        int boxNum = [box[i] intValue];
        int rndkArrayNum = [rndkArray[i] intValue];
        j1 = (j1 + boxNum +rndkArrayNum) % len;
        [box exchangeObjectAtIndex:i withObjectAtIndex:j1];
    }
    
    int a2 = 0;
    int j2 = 0;
    for (int i = 0; i < newData.length; i ++) {
        a2 = (a2 +1) % len;
        int boxNum = [box[a2] intValue];
        j2 = (j2 + boxNum) % len;
        [box exchangeObjectAtIndex:a2 withObjectAtIndex:j2];
        unichar c =  [newData characterAtIndex:i];
        int ASCIIC = [self ascIIToNumber:[NSString stringWithFormat:@"%C",c]];
        
        int value = ([box[a2] intValue] + [box[j2] intValue]) % len;
        int boxValue = [box[value] intValue];
        
        int newValue = ASCIIC ^ boxValue;
        NSString *charStr = [self numberToASCII:newValue];
        result = [NSString stringWithFormat:@"%@%@",result,charStr];
    }
    
    if (isDecode == YES) { // 解密
        if (result.length < 1) {
            NSLog(@"result 为空");
            return @"";
        }
        BOOL bool1 = [[result substringToIndex:10] isEqualToString:@"0000000000"];
        BOOL bool2 = [[result substringToIndex:10] intValue] > [[self getNowTimeTimestamp] intValue];
        
        NSString *string1 = [result substringWithRange:NSMakeRange(10, 16)];
        NSString *md5Str = [[NSString stringWithFormat:@"%@%@",[result substringFromIndex:26],keyB] md5Hash];
        NSString *string2 = [md5Str substringToIndex:16];
        BOOL bool3 = [string2 isEqualToString:string1];
        if ((bool1 || bool2) && bool3) {
            return [result substringFromIndex:26];
        }else {
            return @"";
        }
        
    }else{ // 加密
        NSString *baseStr = [[result base64Encode] stringByReplacingOccurrencesOfString:@"=" withString:@""];
        return [NSString stringWithFormat:@"%@%@",keyC,baseStr];
    }
    
}

调用的辅助方法如下:
实现NSStirng 分类

- (NSString *)md5Hash {
    const char *plain = self.UTF8String;
    unsigned char *digest;
    digest = malloc(CC_MD5_DIGEST_LENGTH);
    
    CC_MD5(plain, (CC_LONG)strlen(plain), digest);
    
    NSString *encode = [self stringFromBytes:digest length:CC_MD5_DIGEST_LENGTH];
    free(digest);
    return encode;
}

#pragma mark - Bytes转字符串
/**
 字符大小写可以通过修改“%02X”中的x修改,下面采用的是大写X  小写用 x
 */
- (NSString *)stringFromBytes:(uint8_t *)bytes length:(int)length {
    NSMutableString *strM = [NSMutableString string];
    
    for (int i = 0; i < length; i++) {
        [strM appendFormat:@"%02x", bytes[i]];
    }
    
    return [strM copy];
}

// base64编码
- (NSString *)base64Encode{
    NSData * body = [self dataUsingEncoding:NSUTF8StringEncoding];
    
    return [body base64EncodedStringWithOptions:0];
}

// base64解码
- (NSString *)base64Dencode
{
    
    NSData *decodeData = [[NSData alloc] initWithBase64EncodedString:self options:0]; //解码
        
    NSString *decodeString = [[NSString alloc] initWithData:decodeData encoding:NSUTF8StringEncoding];
    
    return decodeString;
}

实例方法如下:

// 获取当前时间戳  毫秒
- (NSString *)getNowTimeTimestampms{

    NSDate *datenow = [NSDate date];

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

// 获取当前时间戳  秒
- (NSString *)getNowTimeTimestamp{

    NSDate *datenow = [NSDate date];

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

    return timeSp;

}

- (int)ascIIToNumber:(NSString *)c{
    return [c characterAtIndex:0];
}

- (NSString *)numberToASCII:(int) number{
    return [NSString stringWithFormat:@"%C",(unichar)number];
}

同一套算法实现加密解密,data为需要加密或解密字符串,key为盐值(可以为空),isDecode控制加密或解密

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 202,802评论 5 476
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,109评论 2 379
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 149,683评论 0 335
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,458评论 1 273
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,452评论 5 364
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,505评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,901评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,550评论 0 256
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,763评论 1 296
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,556评论 2 319
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,629评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,330评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,898评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,897评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,140评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,807评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,339评论 2 342