Restkit,停止记录?

Posted

技术标签:

【中文标题】Restkit,停止记录?【英文标题】:Restkit, Stop Logging? 【发布时间】:2012-06-08 07:19:54 【问题描述】:

我想知道.. Restkit 不断显示可达性信息,在我使用它时请求信息。这会在生产版本中自动停止,还是我需要做一些事情来阻止它们显示,比如设置 RKLog 级别?

谢谢

【问题讨论】:

【参考方案1】:

要关闭所有功能,请将其添加到您的应用委托中。

RKLogConfigureByName("*", RKLogLevelOff);

注意:至少在 RestKit v0.20.x 中,您仍然会在开发版本中看到“RestKit logging initialized...”消息。

【讨论】:

【参考方案2】:

要仅抑制可达性消息,请使用以下命令:

RKLogConfigureByName("RestKit/Network/Reachability", RKLogLevelCritical);

查看 lcl_config_components.h 以获取完整列表:

 "restkit"                           "RestKit" 
 "restkit.network"                   "RestKit/Network" 
 "restkit.network.cache"             "RestKit/Network/Cache" 
 "restkit.network.queue"             "RestKit/Network/Queue" 
 "restkit.network.reachability"      "RestKit/Network/Reachability" 
 "restkit.object_mapping"            "RestKit/ObjectMapping" 
 "restkit.core_data"                 "RestKit/CoreData" 
 "restkit.core_data.cache"           "RestKit/CoreData/Cache" 
 "restkit.core_data.search_engine"   "RestKit/CoreData/SearchEngine" 
 "restkit.support"                   "RestKit/Support" 
 "restkit.support.parsers"           "RestKit/Support/Parsers" 
 "restkit.three20"                   "RestKit/Three20" 
 "restkit.ui"                        "RestKit/UI" 
 "restkit.testing"                   "RestKit/Testing" 
 "app"                               "App" 

【讨论】:

我想指出,可以通过添加 RKLogConfigureByName("App", RKLogLevelDebug); 来为他们的应用程序使用 RKLogDebug。我花了一段时间才发现需要这条线才能为我的应用程序使用 RestKit 的日志记录。【参考方案3】:

RestKit 应用程序中的日志消息由 RKLog 调用控制。例如:

    RKLogConfigureByName("RestKit", RKLogLevelWarning); 
    RKLogConfigureByName("RestKit/ObjectMapping", RKLogLevelTrace);
    RKLogConfigureByName("RestKit/Network", RKLogLevelTrace);

RKLog 是通过 Aren Harren 的 lcl_log(参见 http://0xc0.de/LibComponentLogging)库实现的。我只是简单地查看了 lcl 的代码,并没有看到任何会阻止它在生产版本中打印的代码,所以我会确保我的 RKLog 代码不会出现在生产代码中。

【讨论】:

这是否意味着我不必担心它?它会在生产中被删除吗?我不希望我的应用因为有调试消息而被拒绝:) 对不起,如果我不清楚。我没有看到任何防止记录的机制,所以我认为你确实需要删除它。我对此感到有些惊讶。我无法对此进行测试,我的 RestKit 应用尚未在应用商店中。 RestKit 日志在这里解释 restkit-tutorials.com/logging-in-restkit-debug-tips【参考方案4】:

RestKit 被配置为在 DEBUG 构建中显示信息消息及更高版本。在非调试版本中,仅记录警告、错误和关键消息。这是通过RKLogLevelDefault 中的RKLog.h 定义的。

如果您想更改 RestKit 的日志组件之一的日志级别,可以使用 component 名称和 RKLogLevel 日志 level 调用 RKLogConfigureByName(component, level)RKLogConfigureByName("*", RKLogLevelOff) 可用于禁用所有组件的日志记录。确保之前调用了 RKLogInitialize(),因为 RKLogInitialize() 在第一次调用时会覆盖 RestKit 组件的日志级别设置。

如果您想从生产构建中删除所有日志记录代码,您只需将预处理器定义 _LCL_NO_LOGGING 添加到构建设置中即可。详情请见http://0xc0.de/LibComponentLogging。

【讨论】:

【参考方案5】:

Kyle 的解决方案是正确的。 Swift 版本有点不同:

 RKlcl_configure_by_name("*", RKlcl_vOff.rawValue)

【讨论】:

以上是关于Restkit,停止记录?的主要内容,如果未能解决你的问题,请参考以下文章

RestKit,核心数据,神奇的记录,大量数据和滞后的 UI

RestKit 手动保存对象

RestKit 和 Coredata

restkit 映射嵌套数组为空(带有 json 响应的嵌套 restkit 请求)

使用 Restkit 监控网络调用 IOS

RestKit 发布嵌套的托管对象会创建重复项