Google Analytics SDK 创建 SQLite 错误

Posted

技术标签:

【中文标题】Google Analytics SDK 创建 SQLite 错误【英文标题】:Google Analytics SDK creates SQLite errors 【发布时间】:2015-08-08 01:33:52 【问题描述】:

更新

2015 年 8 月 19 日 - 错误似乎已在 3.13 更新中得到修复,尽管他们在更新日志中列出的唯一内容是 "Fixed an issue which caused crashes when using setCampaignParametersFromUrl"。随便拿吧。

2015 年 6 月 8 日 - 仍然遇到此问题。如果我禁用自动发送事件 ([GAI sharedInstance].dispatchInterval = -1;),我仍然会收到错误。因此,我认为问题在于将事件插入到 Google Analytics SQLite 数据库中,不知何故,我自己的当前正在进行的数据库语句正在变成void

2015 年 6 月 10 日 - 仍然遇到崩溃。尝试删除我的扩展 GAITrackedViewController 的控制器并手动发送 createScreenView 轨道,而崩溃频率没有变化。

2015 年 6 月 25 日 - 仍然遇到崩溃。


简介

我已将Google Analytics SDK 3.12 添加到我的 iPhone 应用程序中,一切都按预期运行 - 我运行该应用程序,可以在 Web 界面上看到我设置的所有点击和事件。

我正在我的AppDelegate 中初始化 SDK,就在我的 didFinishLaunchingWithOptions 的顶部,如下所示:

[[GAI sharedInstance] trackerWithTrackingId:GOOGLE_ANALYTICS_ID];

问题

但是,当我尝试自己使用 SQLite 时,我发现运行 Google Analytics 会产生错误。它们可能表现为严重错误,例如:

"Database disk image is malformed" 然后 insta 崩溃 "Disc i/O error" 每当我运行查询时(虽然不会崩溃)

它们也可能导致我自己的 SQLite 查询失败,例如:

if (! sqlite3_prepare_v2(_db, [sql UTF8String], -1, &_statement, NULL) == SQLITE_OK) `
    // ..
    // ..

    if (sqlite3_step(_statement) == SQLITE_ROW) 

将随机导致以下错误:

sqlite3_prepare_v2 EXC_BAD_ACCESS (code=1, address=0x6800000000)

如果我将 SDK 初始化注释掉,那么一切都会恢复到难以置信的稳定状态。再次取消注释,它会在一分钟内使应用崩溃。


抢先答题

    我在运行 8.3 (12F70) 的 iPhone 6 上运行它。

    已尝试卸载并重新安装应用程序。

    我已经添加了 Google Analytics 工作的所有先决条件;库中的所有.m 文件、libGoogleAnalyticsServices.a 文件以及Linked Frameworks and Libraries

    我也有 Crashlytics,但尝试从代码 ([Fabric with:@[CrashlyticsKit]];) 中将其注释掉,并从 Linked Frameworks and Libraries 中删除其库,结果完全相同。


代码

设置类

// In didFinishLaunchingWithOptions
[Db setup];
[Db connect];

访问类

Db * db = [[Db alloc] init];

if ([db prepare:@"SELECT * FROM `table` WHERE `id` = ?" withBindings:@[@"123"]]) 
    while ([db stepThrough]) 
        // ..
    


[db finalise];

(已用 cmets 指出错误出现的位置)

@implementation Db

static sqlite3  * _db;
static NSString * _dbPath;

#pragma mark - Setup

+ (BOOL)setup 
    NSString      * sqlBundlePath   = [[NSBundle mainBundle] pathForResource:@"db" ofType:@"sqlite"];
    NSString      * documentsFolder = NSSearchPathForDirectoriesInDomains(NSDocumentDirectory, NSUserDomainMask, YES)[0];
    NSString      * sqlDocumentPath = [[documentsFolder stringByAppendingPathComponent:@"db"] stringByAppendingPathExtension:@"sqlite"];
    NSFileManager * fileManager     = [NSFileManager defaultManager];

    if (! [fileManager fileExistsAtPath:sqlDocumentPath]) 
        NSError * error;
        BOOL success = [fileManager copyItemAtPath:sqlBundlePath toPath:sqlDocumentPath error:&error];

        if (! success) 
            return NO;
        
    

    _dbPath = sqlDocumentPath;
    return YES;


+ (BOOL)connect 
    sqlite3_config(SQLITE_CONFIG_SERIALIZED);
    return sqlite3_open([_dbPath UTF8String], &_db);


#pragma mark - Querying

- (BOOL)prepare:(NSString *)sql withBindings:(NSArray *)bindings 
    // ERROR CAN OCCUR ON THE FOLLOWING LINE
    if (! sqlite3_prepare_v2(_db, [sql UTF8String], -1, &_statement, NULL) == SQLITE_OK) 
        NSLog(@"Error whilst preparing query: %s", sqlite3_errmsg(_db));
        sqlite3_finalize(_statement);
        return NO;
    

    for (int i = 0; i < [bindings count]; i++) 
        sqlite3_bind_text(_statement,
                          i + 1,
                          [bindings[i] isKindOfClass:[NSNull class]] ? [@"" UTF8String] : [bindings[i] UTF8String],
                          -1,
                          SQLITE_TRANSIENT);
    

    return YES;


- (BOOL)stepThrough 
    // ERROR CAN OCCUR ON THE FOLLOWING LINE
    if (sqlite3_step(_statement) == SQLITE_ROW) 
        return YES;
    

    sqlite3_finalize(_statement);
    return NO;


- (void)finalise 
    sqlite3_finalize(_statement);


@end

【问题讨论】:

看来你做对了。您可以使用其他平台进行分析吗? 理想情况下,我们希望使用谷歌分析,因为我们也将它用于我们的网站,因此它将与我们的转化目标等相结合。 【参考方案1】:

升级到新版本的 SDK (3.13) 解决了这个问题(至少对我而言),尽管他们的更新日志没有特别提及。

【讨论】:

以上是关于Google Analytics SDK 创建 SQLite 错误的主要内容,如果未能解决你的问题,请参考以下文章

在 iOS 上将 Google Analytics 与 Swift 结合使用

如何在 chrome 扩展中加载 Google Analytics 和 Facebook SDK?

Firebase+GTM SDK - 在 Google Analytics 中跟踪异常和崩溃

无法使用带有 IDFA 的 Google Analytics iOS SDK 验证人口统计报告的跟踪代码

使 Box iOS SDK WebAPI 和 Google Analytics iOS SDK 2.0beta3 协同工作

iOS 中的 Google Analytics SDK 3.0 _sqlite3 链接器错误