如何使用Objective-C在IOS中读取和存储系统日志消息

时间:2016-01-01 09:10:09

标签: ios objective-c logging nslog

我的目的是阅读与我的应用程序有关的所有系统日志消息(system.log文件中存在的所有日志消息),并将其存储在应用程序的Document文件夹中的日志文件中。 我浏览了this code并使用了this answer

这是我的代码:

NSDate *currentDate = [[NSDate alloc] init];

NSDateFormatter *formatter = [[NSDateFormatter alloc] init];
[formatter setDateFormat:[NSString stringWithFormat: @"dd-MM-yyyy-HHmmss"]];

NSString *logFileName = [[formatter stringFromDate:currentDate] stringByAppendingString:@".log"];

NSError *error;
NSMutableString *content = [[NSMutableString alloc] init];


 aslmsg q, m;
 int i;
 const char *key, *val;

 q = asl_new(ASL_TYPE_QUERY);

 aslresponse r = asl_search(NULL, q);

 while (NULL != (m = asl_next(r)))
 {
     NSMutableDictionary *tmpDict = [NSMutableDictionary dictionary];

     for (i = 0; (NULL != (key = asl_key(m, i))); i++)
     {
         NSString *keyString = [NSString stringWithUTF8String:(char *)key];

         val = asl_get(m, key);

         NSString *string = [NSString stringWithUTF8String:val];
         [tmpDict setObject:string forKey:keyString];
     }

     [content appendString:[NSString stringWithFormat:@"%@",tmpDict]];
 }

asl_release(r);

NSString *filePath = [[NSSearchPathForDirectoriesInDomains(NSDocumentDirectory, NSUserDomainMask, YES) firstObject] stringByAppendingPathComponent:logFileName];

[[NSString stringWithString:content] writeToFile:filePath atomically:YES encoding:NSUTF8StringEncoding error:&error];

这只是我的IOS应用程序代码的一部分。我在IOS模拟器上运行我的应用程序。

成功创建日志文件。它有一些主要是JSON的内容。

但是,该文件没有我通过NSLog输出的那些日志消息,但这些日志消息存在于系统的日志文件中。

我对IOS开发很新。如上所述,我的目的是访问系统的日志文件。所以我想捕获每条日志消息并将其保存到我的个人目录中。

我在Stackoverflow上搜索了很多。但是,我还没有找到可以帮助我的确切线程。有人能指导我吗? (我希望这个问题不会重复。)

1 个答案:

答案 0 :(得分:0)

我想您希望他们稍后检查它们,以防您发现错误。也许您可以尝试Bugfender(http://bugfender.com),它是我们创建的工具,用于在开发应用程序时从客户处获取日志。

有了它,您将能够获得所有NSLog呼叫。

如果您不想使用Bugfender,您检查的答案是正确的方法。在我们的例子中,我们使用记录的here

函数