一段用MyGTMBase64的加密算法

两头大概都知道,中间那段不太懂
以下是我网上找到的方法,测试不太对

+ (NSString *)encrypt:(NSString *)sText encryptOrDecrypt:(CCOperation)encryptOperation key:(NSString *)key  
{  
    const void *dataIn;  
    size_t dataInLength;  
      
    if (encryptOperation == kCCDecrypt)//传递过来的是decrypt 解码  
    {  
        //解码 base64  
        NSData *decryptData = [GTMBase64 decodeData:[sText dataUsingEncoding:NSUTF8StringEncoding]];//转成utf-8并decode  
        dataInLength = [decryptData length];  
        dataIn = [decryptData bytes];  
    }  
    else  //encrypt  
    {  
        NSData* encryptData = [sText dataUsingEncoding:NSUTF8StringEncoding];  
        dataInLength = [encryptData length];  
        dataIn = (const void *)[encryptData bytes];  
    }  
      
    /* 
     DES加密 :用CCCrypt函数加密一下,然后用base64编码下,传过去 
     DES解密 :把收到的数据根据base64,decode一下,然后再用CCCrypt函数解密,得到原本的数据 
     */  
    CCCryptorStatus ccStatus;  
    uint8_t *dataOut = NULL; //可以理解位type/typedef 的缩写(有效的维护了代码,比如:一个人用int,一个人用long。最好用typedef来定义)  
    size_t dataOutAvailable = 0; //size_t  是操作符sizeof返回的结果类型  
    size_t dataOutMoved = 0;  
      
    dataOutAvailable = (dataInLength + kCCBlockSizeDES) & ~(kCCBlockSizeDES - 1);  
    dataOut = malloc( dataOutAvailable * sizeof(uint8_t));  
    memset((void *)dataOut, 0x0, dataOutAvailable);//将已开辟内存空间buffer的首 1 个字节的值设为值 0  
      
    const void *vkey = (const void *) [key UTF8String];  
    const void *iv = (const void *) [initIv UTF8String];  
      
    //CCCrypt函数 加密/解密  
    ccStatus = CCCrypt(encryptOperation,//  加密/解密  
                       kCCAlgorithmDES,//  加密根据哪个标准(des,3des,aes。。。。)  
                       kCCOptionPKCS7Padding,//  选项分组密码算法(des:对每块分组加一次密  3DES:对每块分组加三个不同的密)  
                       vkey,  //密钥    加密和解密的密钥必须一致  
                       kCCKeySizeDES,//   DES 密钥的大小(kCCKeySizeDES=8)  
                       iv, //  可选的初始矢量  
                       dataIn, // 数据的存储单元  
                       dataInLength,// 数据的大小  
                       (void *)dataOut,// 用于返回数据  
                       dataOutAvailable,  
                       &dataOutMoved);  
      
    NSString *result = nil;  
      
    if (encryptOperation == kCCDecrypt)//encryptOperation==1  解码  
    {  
        //得到解密出来的data数据,改变为utf-8的字符串  
        result = [[[NSString alloc] initWithData:[NSData dataWithBytes:(const void *)dataOut length:(NSUInteger)dataOutMoved] encoding:NSUTF8StringEncoding] autorelease];  
    }  
    else //encryptOperation==0  (加密过程中,把加好密的数据转成base64的)  
    {  
        //编码 base64  
        NSData *data = [NSData dataWithBytes:(const void *)dataOut length:(NSUInteger)dataOutMoved];  
        result = [GTMBase64 stringByEncodingData:data];  
    }  
      
    return result;  
}  

你在第一个方块的最末尾下个断点,然后用LLDB单步调一下,把所有的objc_msgSend相关信息打印出来就清楚了

调试了,就知道了传进来的是NSConcreteMutableData类型,然后呢,我能再得到什么信息可以全部还原这个算法呢。。

你继续ni,把所有的objc_msgSend都打印出来就可以了

objc_msgSend怎么打印,书里没有提到

查了写资料还是不会,老大如果没时间细说,还请帮忙提供点资料看看,感激啊

每天来看看,期待大神指点

就是跳转到objc_msgSend的位置,打印出 r0 r1 r2 (或者x0 x1 x2…)
po $r0
p (char*)$r1
po $r2

书上到处都是哦:grin:

1 个赞

尝试打印了,没有得到有用的信息,不过还是稀里糊涂的试出来了,非常高兴,属于程序员的满足!

兄弟你怎么试的啊?我知道密钥,存在r4寄存器也就是第四个参数传入cccrypt中,但是密钥少了一位。不知道怎么补全的,另外这里看不到初始化向量,难道置为0就可以了吗。