开发者

How to convert NSData of Image from database to NSString in iPhone?

开发者 https://www.devze.com 2023-02-14 10:22 出处:网络
I am converting NSData of Image from database to NSString in iPhone Here is my code imageData1 = [[NSData alloc] initWithBytes:sqlite3_column_blob(compiledStatement, 2) length: sqlite3_column_bytes(

I am converting NSData of Image from database to NSString in iPhone

Here is my code

imageData1 = [[NSData alloc] initWithBytes:sqlite3_column_blob(compiledStatement, 2) length: sqlite3_column_bytes(compiledStatement, 2)];           
NSLog(@"the data length %d",[imageData1 length]);
NSString* newStr1 = [[NSString alloc] initWithData:imageData1 encoding:NSUTF8StringEncoding];

The length of data is 6511 , but the newstr1 is nil

With reference to this stack overflow question. I can't create a UTF-8 encoded string out of just any arbitrary binary data from the database - the data needs to actually be UTF-8 encoded. I need it in the format of NSString only, to give it as input to a CSV file.

EDIT:

imageData1 = [[NSData alloc] initWithBytes:sqlite3_column_blob(compiledStatement, 3) length: sqlite3_column_bytes(compiledStatement, 3)];           
NSString * Str1 = [NSString base64StringFromData: imageData1 length: [imageData1 length]];
NSData *data1=[NSData base64DataFromString:Str1];
NSString* newStr1 = [[NSString alloc] initWithData:data1 encoding:NSUTF8StringEncoding];

Af开发者_如何学运维ter base 64 encoding and decoding also my string is nil.


Chances are very good that you don't actually want to dump raw binary data into a CSV file. You probably want to look into base64-encoding the data instead. This previous answer should be able to help you with that.

0

精彩评论

暂无评论...
验证码 换一张
取 消

关注公众号