gpt4 book ai didi

ios - 在 iOS 7.0 模拟器上以编程方式授予对 NAB 的访问权限

转载 作者:可可西里 更新时间:2023-11-01 03:46:04 24 4
gpt4 key购买 nike

是否可以通过编程方式授予对 iOS 7.0 模拟器上的 native 地址簿 (NAB) 的访问权限?我正在编写需要对 NAB 进行写入访问xctest 单元测试。单元测试在 iOS 7.0 模拟器 上运行,是持续集成过程的一部分,不涉及任何用户交互。

目前,除非用户通过“TestApp”想要访问您的联系人警报明确授予访问权限,否则对 NAB 的访问将被拒绝。

最佳答案

本着分享的精神,我将回答我自己的问题。在其他权限中,Address Book 访问权限存储在 TCC.db 数据库中,该数据库位于 iPhone Simulator 文件夹的 /Library/TCC/ 中.

e.g. /Users/useriko/Library/Application Support/iPhone Simulator/7.1-64/Applications/[appGUID]/Library/TCC/TCC.db

权限存储在 TCC.db 数据库的 access 表中。 access 表架构是: TCC.db schema

我们感兴趣的领域是:

  1. service - 权限类型
  2. client - 应用标识符
  3. allowed - 是否授予权限?

为了授予Access Book 权限,应将适当的记录插入到access 表中(如果已存在则更新)。插入或更新记录后,表格应如下所示: access table after update

我编写了以下方法来更新 TCC.db 数据库。

#import <sqlite3.h>

- (void)grantAccessBookAccess {
NSArray *paths = NSSearchPathForDirectoriesInDomains(NSDocumentDirectory, NSUserDomainMask, YES);
// tccDbPath: /Users/useriko/Library/Application Support/iPhone Simulator/7.1-64/Applications/FB8DF5E9-94B8-4CA9-A167-43AFE794B94E/Document

NSString *tccDbPath = nil;
tccDbPath = [[[[paths objectAtIndex:0]
stringByDeletingLastPathComponent] // remove Document
stringByDeletingLastPathComponent] // remove [appGUID]
stringByDeletingLastPathComponent]; // remove Applications

// tccDbPath: /Users/useriko/Library/Application Support/iPhone Simulator/7.1-64/

tccDbPath = [[[tccDbPath stringByAppendingPathComponent:@"Library"]
stringByAppendingPathComponent:@"TCC"]
stringByAppendingPathComponent:@"TCC.db"];

// tccDbPath: /Users/useriko/Library/Application Support/iPhone Simulator/7.1-64/Library/TCC/TCC.db

sqlite3 *database;
if(sqlite3_open([tccDbPath UTF8String], &database) != SQLITE_OK) {
NSLog(@"Error while opening database. %s", sqlite3_errmsg(database));
return;
}

NSString *updateSql = @"INSERT OR REPLACE INTO access (service, client, client_type, allowed, prompt_count) VALUES (\"kTCCServiceAddressBook\",\"com.your.app.id\",0,1,1);";

int rc;
char* errmsg;
const char *sql = [updateSql UTF8String];
rc = sqlite3_exec(database, sql, NULL, NULL, &errmsg);
if (rc != SQLITE_OK) {
NSLog(@"Error updating access table. %s", errmsg);
sqlite3_free(errmsg);
}

sqlite3_close(database);
}

由于显而易见的原因,目标应该链接到libsqlite3.dylib

不要忘记将 updateSql 中的应用标识符 (com.your.app.id) 更改为您的应用标识符。

关于ios - 在 iOS 7.0 模拟器上以编程方式授予对 NAB 的访问权限,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/24497022/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com