如何将NSData
转换为base64
。我有NSData
并希望转换为base64
我该怎么做?
答案 0 :(得分:50)
修改强>
从OS X 10.9 / iOS 7开始,它内置于框架中。
请参阅-[NSData base64EncodedDataWithOptions:]
在iOS7 / OS X 10.9之前:
Matt Gallagher在这个主题上写了an article。在底部,他提供了一个链接到他的iPhone可嵌入代码。
在Mac上你可以使用OpenSSL库,在iPhone上他自己编写了impl。
答案 1 :(得分:27)
//from: http://cocoadev.com/BaseSixtyFour
+ (NSString*)base64forData:(NSData*)theData {
const uint8_t* input = (const uint8_t*)[theData bytes];
NSInteger length = [theData length];
static char table[] = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=";
NSMutableData* data = [NSMutableData dataWithLength:((length + 2) / 3) * 4];
uint8_t* output = (uint8_t*)data.mutableBytes;
NSInteger i;
for (i=0; i < length; i += 3) {
NSInteger value = 0;
NSInteger j;
for (j = i; j < (i + 3); j++) {
value <<= 8;
if (j < length) {
value |= (0xFF & input[j]);
}
}
NSInteger theIndex = (i / 3) * 4;
output[theIndex + 0] = table[(value >> 18) & 0x3F];
output[theIndex + 1] = table[(value >> 12) & 0x3F];
output[theIndex + 2] = (i + 1) < length ? table[(value >> 6) & 0x3F] : '=';
output[theIndex + 3] = (i + 2) < length ? table[(value >> 0) & 0x3F] : '=';
}
return [[[NSString alloc] initWithData:data encoding:NSASCIIStringEncoding] autorelease];
}
答案 2 :(得分:20)
作为更新,iOS7 SDK在NSData (NSDataBase64Encoding)
上有一个带有方法
-[NSData base64EncodedStringWithOptions:]
-[NSData initWithBase64EncodedString:options:]
-[NSData initWithBase64EncodedData:options:]
-[NSData base64EncodedDataWithOptions:]
应该避免必须推出自己的类别方法
答案 3 :(得分:6)
超级简单的Google图书馆代码here.
只需使用+rfc4648Base64StringEncoding
获取实例,然后使用encode
/ decode
函数。
这是一件美好的事情。 (不要忘记从根目录中获取头文件和GTMDefines.h
标题。)
答案 4 :(得分:4)
这并不容易。因为在c或obj-c中没有内置支持。这就是我正在做的事情(这基本上让CL为我做了):
- (NSString *)_base64Encoding:(NSString *) str
{
NSTask *task = [[[NSTask alloc] init] autorelease];
NSPipe *inPipe = [NSPipe pipe], *outPipe = [NSPipe pipe];
NSFileHandle *inHandle = [inPipe fileHandleForWriting], *outHandle = [outPipe fileHandleForReading];
NSData *outData = nil;
[task setLaunchPath:@"/usr/bin/openssl"];
[task setArguments:[NSArray arrayWithObjects:@"base64", @"-e", nil]];
[task setStandardInput:inPipe];
[task setStandardOutput:outPipe];
[task setStandardError:outPipe];
[task launch];
[inHandle writeData:[str dataUsingEncoding: NSASCIIStringEncoding]];
[inHandle closeFile];
[task waitUntilExit];
outData = [outHandle readDataToEndOfFile];
if (outData)
{
NSString *base64 = [[[NSString alloc] initWithData:outData encoding:NSUTF8StringEncoding] autorelease];
if (base64)
return base64;
}
return nil;
}
你这样使用它:
NSString *b64str = [strToConvert _base64Encoding:strToConvert];
这不是我的代码 - 我在这里找到了它:http://www.cocoadev.com/index.pl?BaseSixtyFour并且效果很好。您可以随时将其转换为+()方法。
哦,并为此方法获取NSData到NSString:
NSString *str = [[NSString alloc] initWithData:data encoding:NSASCIIStringEncoding];
答案 5 :(得分:2)
iOS始终包含对base64编码和解码的内置支持。如果您查看resolv.h
,您应该看到两个函数b64_ntop
和b64_pton
。 Square SocketRocket库提供了如何从objective-c使用这些函数的合理示例。
这些功能经过了充分的测试和可靠 - 与您在随机互联网帖子中找到的许多实现不同。
不要忘记链接libresolv.dylib
。
如果您链接对抗iOS 7 SDK,则可以使用较新的方法initWithBase64Encoding:
和base64EncodedDataWithOptions:
。这些存在于以前的版本中,但是是私有的。因此,如果您链接到6 SDK,您可能会遇到未定义的行为。这将是仅在链接7 SDK时如何使用它的示例:
#ifndef __IPHONE_7_0
// oh no! you are using something unsupported!
// Call and implementation that uses b64_pton here
#else
data = [[NSData alloc] initWithBase64Encoding:string];
#endif
答案 6 :(得分:0)
我修改了上面的代码以满足我的需求,构建了一个HTTP POST。我能够跳过NSString步骤,并在BASE64代码中包含换行符,至少有一个Web服务器发现更可口:
#define LINE_SIZE 76
//originally from: http://www.cocoadev.com/index.pl?BaseSixtyFour
// via joshrl on stockoverflow
- (void) appendBase64Of: (NSData *)inData to:(NSMutableData *)outData {
const uint8_t* input = (const uint8_t*)[inData bytes];
NSInteger length = [inData length];
static char table[] = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=";
uint8_t buf[LINE_SIZE + 4 + 2];
size_t n = 0;
NSInteger i;
for (i=0; i < length; i += 3) {
NSInteger value = 0;
NSInteger j;
for (j = i; j < (i + 3); j++) {
value <<= 8;
if (j < length) {
value |= (0xFF & input[j]);
}
}
buf[n + 0] = table[(value >> 18) & 0x3F];
buf[n + 1] = table[(value >> 12) & 0x3F];
buf[n + 2] = (i + 1) < length ? table[(value >> 6) & 0x3F] : '=';
buf[n + 3] = (i + 2) < length ? table[(value >> 0) & 0x3F] : '=';
n += 4;
if (n + 2 >= LINE_SIZE) {
buf[n++] = '\r';
buf[n++] = '\n';
[outData appendBytes:buf length:n];
n = 0;
}
}
if (n > 0) {
buf[n++] = '\r';
buf[n++] = '\n';
[outData appendBytes:buf length:n];
}
return;
}