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 协同工作