Cocoa将octals的NSArray / NSString转换为NSData?

我试图将这些C代码转换为Cocoa,我正在努力弄清楚如何。
  char *deskey = "123 456 789 101 112 131 415 161";
  unsigned char key[16];
  memset(key, 0, sizeof(key));
  sscanf(deskey, "%o %o %o %o %o %o %o %o",
    (int*)&key[0], (int*)&key[1], (int*)&key[2],
    (int*)&key[3], (int*)&key[4], (int*)&key[5],
    (int*)&key[6], (int*)&key[7]);
我尝试过使用NSMutableArray和NSData,但没有运气。我能够扫描字符串并提取数字,但我不确定如何在此之后存储到NSData中。
  NSMutableArray *enckey = [[[NSMutableArray alloc] init] autorelease];
  NSScanner *scanner = [NSScanner scannerWithString:self.deskey];
  int pos = 0;

  while ([scanner isAtEnd] == NO) {
    if ([scanner scanInt:&pos]) {
      [enckey addObject:[NSString stringWithFormat:@"%o", pos]];
    }
    else {
      NSLog(@"Your DES key appears to be invalid.");
      return;
    }
  }
基本上尝试将ascii DES密钥转换为字符串以用于Triple DES加密。非常感谢任何帮助,谢谢!     
已邀请:
@Keenan“我希望避免使用sscanf和char *代替Cocoa类”。那么你可以做到,但是你希望生产什么?如果你想要一个字节数组作为结果,那么你需要坚持
unsigned char[]
,这就引出了一个问题,为什么你首先要在
NSString
上进行解析。 这是C代码的Objective-C转换。请注意,八进制被Cocoa视为古代历史,因此它的解析类只处理十进制和十六进制,因此您需要编写自己的或使用标准C函数(下面的
strtol
)。 这个例子产生了
unsigned char[]
NSMutableArray
- 选择一个。
// There are no checks in the code, like in the original...
// BTW 789 is not an octal number...
NSString *descKey = @"123 456 789 101 112 131 415 161";         //    char *deskey = "123 456 789 101 112 131 415 161";
// pick one...
NSMutableArray *keyObjC = [NSMutableArray new];                 //    unsigned char key[16];
unsigned char keyC[16];
//    memset(key, 0, sizeof(key));

// As @JeremyP has pointed out the sscanf is wrong as %o produces a 4-byte value and you only want a 1-byte one.
// In C you would therefore need key to be an array of ints and then assign each element to a byte (unsigned char),
// or parse a different way.

unsigned ix = 0;    // for keyC choice only
NSArray *numbers = [descKey componentsSeparatedByString:@" "];  //    sscanf(deskey, "%o %o %o %o %o %o %o %o",
for (NSString *aNumber in numbers)                              //           (int*)&key[0], (int*)&key[1], (int*)&key[2],
{                                                               //           (int*)&key[3], (int*)&key[4], (int*)&key[5],
                                                                //           (int*)&key[6], (int*)&key[7]);
    unsigned char next = (unsigned char)strtol([aNumber UTF8String], NULL, 8);
    keyC[ix++] = next;                                          // for keyC choice
    [keyObjC addObject:[NSNumber numberWithUnsignedChar:next]]; // keyObjC choice
}
如果你想接近Python的一行,只需将迭代压缩为:
for (NSString *aNumber in [descKey componentsSeparatedByString:@" "]) { [keyObjC addObject:[NSNumber numberWithUnsignedChar:(unsigned char)strtol([aNumber UTF8String], NULL, 8)]]; }
但它当然更长!     
快速而肮脏的方法是采用原始代码
char *deskey = "123 456 789 101 112 131 415 161";
unsigned char key[16];
memset(key, 0, sizeof(key));
sscanf(deskey, "%o %o %o %o %o %o %o %o",
       (int*)&key[0], (int*)&key[1], (int*)&key[2],
       (int*)&key[3], (int*)&key[4], (int*)&key[5],
       (int*)&key[6], (int*)&key[7]);
并添加以下行:
NSData* keyData = [NSData dataWithBytes: key length: sizeof key];
除了你的sscanf看起来非常错误。密钥的元素是字符,而不是整数。     
由于CRD已经很好地向您展示了正确的解决方案,我将使用我的答案解释为什么您的解决方案不起作用。
  unsigned char key[16];
  memset(key, 0, sizeof(key));
  sscanf(deskey, "%o %o %o %o %o %o %o %o",
    (int*)&key[0], (int*)&key[1], (int*)&key[2],
    (int*)&key[3], (int*)&key[4], (int*)&key[5],
    (int*)&key[6], (int*)&key[7]);
说谎编译器永远不会解决问题。
key
是一个
unsigned char
s的数组。告诉编译器,在函数调用
sscanf
中,指向数组的指针是指向
int
s的指针并不能使它们如此;每个人指向的存储仍然存储为
unsigned char
,而不是更多。 结果是,每次尝试在您提供的地址存储一个
int
会覆盖前一个three15ѭ的四分之三。结果是,
sscanf
只不过是一种比ѭ20更难做的事情。 我说“小一点”而不是“不再”是有原因的:
sscanf
调用还会在数组末尾写入22英寸的字节,所以你也在粉碎堆栈并设置潜在的崩溃。
    if ([scanner scanInt:&pos]) {
      [enckey addObject:[NSString stringWithFormat:@"%o", pos]];
scanInt:
解析十进制字符串中的数字。
stringWithFormat:
同样做它的名字:它创造一个字符串。使用您提供的格式,它会将数字转换为字符串,而不是相反。 因此,您使用
scanInt:
来解析十进制数,并使用
stringWithFormat:
将其转换为八进制(并将其编码回字符串)。假设,从基于
sscanf
的代码,输入是八进制的,这与你想要的相反。 这段代码肯定会给你数字,但它会给你错误的数字,这几乎和gave14ѭ代码一样糟糕,它给你全部零和一个崩溃。 您无法使用NSScanner扫描八进制数。 我也不确定你为什么叫这个变量
pos
,因为它似乎不是一个位置。当然,这不是
scanInt:
给你的。   我能够扫描字符串并提取数字,但我不确定如何在此之后存储到NSData中。 请参阅NSData文档。   我尝试过使用NSMutableArray和NSData,但没有运气。 这与解决输入数据的问题无关。 我不确定NSArray或C数组(后者可选地包装在NSData中)是否是放置结果的正确位置。一旦解析了数字,这取决于您想要传递数字的位置。     

要回复问题请先登录注册