经过身份验证的Dev用户无法在模拟器中写入/创建CloudKit公共数据库

问题描述

我的设备既可以在模拟器上运行,也可以在测试iPhone上运行。我想将新记录保存到Cloudkit数据库。我可以在物理测试设备上创建记录,但不能在模拟器中创建记录。当我将其提交给Apple审核时,他们也因此拒绝了它。两台设备均已登录到iCloud。在使用以下代码保存记录之前已确认这一点:

CKContainer.default().accountStatus { (accountStatus,error) in
        switch accountStatus {
        case .available:
            print("iCloud Available")
        case .noAccount:
            print("No iCloud account")
        case .restricted:
            print("iCloud restricted")
        case .CouldNotDetermine:
            print("Unable to determine iCloud status")
        }
    }

我用来保存的代码非常简单,并且在真实设备上也没有任何问题:

static func saveUser(user: UserElement,completion: @escaping (Result<UserElement,Error>) ->
    ()) {
    let itemRecord = CKRecord(recordtype: "userInfo")
    
    itemRecord["uniqueID"] = user.bossID as CKRecordValue
    itemRecord["screenName"] = user.screenName as CKRecordValue
    itemRecord["shareCode"] = user.shareCode as CKRecordValue
    itemRecord["subscribedBosses"] = user.subscribedBosses as CKRecordValue

    let container = CKContainer(identifier: "iCloud.Caz4Short.WatChaDoin")
    container.publiccloudDatabase.save(itemRecord) { (record,err) in
        dispatchQueue.main.async {
            if let err = err {
                print("error on run")
                completion(.failure(err))
                return
            }
            
            guard let record = record else {
                print("record")
                completion(.failure(CloudKitHelperError.recordFailure))
                return
            }
            
            let id = record.recordID
            guard let boss = record["uniqueID"] as? String else {
                print("record ID")
                completion(.failure(CloudKitHelperError.recordIDFailure))
                return
            }
            guard let name = record["screenName"] as? String else {
                
                print("screenname")
                completion(.failure(CloudKitHelperError.castFailure))
                return
            }
            guard let bossCode = record["shareCode"] as? String else {
                print("Code")
                completion(.failure(CloudKitHelperError.castFailure))
                return
            }
            guard let subs = record["subscribedBosses"] as? [String] else {
                completion(.failure(CloudKitHelperError.castFailure))
                return
            }
            let element = UserElement(recordID: id,bossID: boss,screenName: name,shareCode: bossCode,subscribedBosses: subs)
            completion(.success(element))
        }
    }
}

代码在“运行时出错”失败,并显示错误消息

错误保存记录 defaultOwner >到服务器:不允许CREATE操作

当我尝试修改记录时会遇到类似的错误,只是它说WRITE而不是CREATE。我仍然可以毫无问题地读取记录。这使我认为我忘记了为该区域设置安全角色,但事实并非如此。经过身份验证的用户,并且为所有区域选择了“读取”,“创建”和“写入”。创建者还具有读取和写入功能。我也已经在计算机上登录iCloud并很久以前接受了iCloud帐户的条款和条件,因此它不像需要设置的新帐户那样。任何想法将不胜感激,因此它不会再次被拒绝!

Image of Security Role Selections

解决方法

暂无找到可以解决该程序问题的有效方法,小编努力寻找整理中!

如果你已经找到好的解决方法,欢迎将解决方案带上本链接一起发送给小编。

小编邮箱:dio#foxmail.com (将#修改为@)