DES解密问题

时间:2014-02-04 11:41:28

标签: ios iphone objective-c encryption des

我在ECB模式下使用DES解密。我使用以下代码进行解密:

NSString *token = @"kRAz86UoZd5tFKf0xv8TKg==";
NSString *key = @"meristem";

const void *vplainText;
size_t plainTextBufferSize;

NSData *EncryptData = [[NSData alloc] initWithBase64EncodedString:token options:0];
plainTextBufferSize = [EncryptData length];
vplainText = [EncryptData bytes];

//plainTextBufferSize = [token length];
//vplainText = (const void *) [token UTF8String];

CCCryptorStatus ccStatus;
uint8_t *bufferPtr = NULL;
size_t bufferPtrSize = 0;
size_t movedBytes;

bufferPtrSize = (plainTextBufferSize + kCCBlockSize3DES) & ~(kCCBlockSize3DES - 1);
bufferPtr = malloc( bufferPtrSize * sizeof(uint8_t));
memset((void *)bufferPtr, 0x0, bufferPtrSize);

NSString *initVec = @"init Vec";
const void *vkey = (const void *) [key UTF8String];
const void *vinitVec;
vinitVec = (const void *) [initVec UTF8String];

ccStatus = CCCrypt(kCCDecrypt,
                   kCCAlgorithmDES,
                   kCCOptionPKCS7Padding | kCCOptionECBMode,
                   vkey, //"123456789012345678901234", //key
                   kCCKeySizeDES,
                   NULL,// vinitVec, //"init Vec", //iv,
                   vplainText, //"Your Name", //plainText,
                   plainTextBufferSize,
                   (void *)bufferPtr,
                   bufferPtrSize,
                   &movedBytes);

NSData *myData = [NSData dataWithBytes:(const void *)bufferPtr length:(NSUInteger)movedBytes];
NSString *decodedString = [[NSString alloc] initWithData:myData encoding:NSUTF8StringEncoding];
NSLog(@"dis is data %@",decodedString);

在这里,您可以看到我的加密字符串是 kRAz86UoZd5tFKf0xv8TKg == ,其结果是 vishal thakur 。但是通过使用上面的代码进行解密,我只得到 vishal t 。我不明白为什么没有得到完整的字符串。请任何人都可以告诉我我做错了什么。

2 个答案:

答案 0 :(得分:2)

我已经通过替换此行解决了我的问题

plainTextBufferSize = [EncryptData length];  

进入

plainTextBufferSize = [EncryptData length]+1;

答案 1 :(得分:1)

<强>编辑: 我认为它与plainTextBufferSize有关,这会导致您在CCCrypt函数中调用此问题。

尝试在CCCrypt功能之前更改其值。