0

正如标题所示,我想在现有应用程序上实现 iCloud Drive 支持,其中 ubiquity 容器以旧样式 $(TeamIdentifierPrefix) 为前缀。对于我的一生,我无法让它发挥作用。

最初我尝试了苹果自己的步骤,如下所述:https ://developer.apple.com/library/content/documentation/General/Conceptual/iCloudDesignGuide/Chapters/DesigningForDocumentsIniCloud.html#//apple_ref/doc/uid/TP40012094-CH2- SW20

不幸的是,这没有奏效。(我记得每次构建都会增加捆绑版本)

按照这篇文章中提供的步骤:iCloud Drive Folder,我能够让我的应用程序出现在 iCloud Drive 中,但是我现有的文档无法访问,因为它们位于例如 X123F4563T8.com.example.app 而不是新创建的 iCloud。 com.example.app。

我尝试了无数不同标识符配置的变体,试图让 iCloud Drive 指向旧的普遍存在的容器,但无济于事。

我的权利文件如下所示(使用我的应用程序自己的标识符):

<key>com.apple.developer.icloud-container-identifiers</key>
<array>
    <string>iCloud.com.example.AppName</string>
</array>
<key>com.apple.developer.icloud-services</key>
<array>
    <string>CloudDocuments</string>
</array>
<key>com.apple.developer.ubiquity-container-identifiers</key>
<array>
    <string>iCloud.com.example.AppName</string>
</array>
<key>keychain-access-groups</key>
<array>
    <string>$(AppIdentifierPrefix)com.example.AppName</string>
</array>

第一个关键似乎是决定使用哪个无处不在的目录。

之前设置为:

<key>com.apple.developer.icloud-container-identifiers</key>
<array>
    <string>$(TeamIdentifierPrefix)com.example.AppName</string>
</array>

我缩小了搜索范围,发现这是此键的值似乎是是否使用(旧式)iCloud Documents 的决定因素

 $(TeamIdentifierPrefix)com.example.AppName

或 iCloud 云盘,

 iCloud.com.example.AppName

为了完整起见,我的 Info.plist 中包含以下内容:

<key>iCloud.com.example.AppName</key>
<dict>
    <key>NSUbiquitousContainerIsDocumentScopePublic</key>
    <true/>
    <key>NSUbiquitousContainerName</key>
    <string>App Name For Drive</string>
    <key>NSUbiquitousContainerSupportedFolderLevels</key>
    <string>Any</string>
</dict>

我也没有忽略:

<key>com.apple.developer.ubiquity-container-identifiers</key>
<array>
    <string>iCloud.com.example.AppName</string>
</array>

但是,这个值似乎对结果没有影响。

4

1 回答 1

0

为了使它工作,以下条目被添加到我的 Info.plist 中:

<key>NSUbiquitousContainers</key>
<dict>
    <key>iCloud.com.Example.AppName</key>
    <dict>
        <key>NSUbiquitousContainerIsDocumentScopePublic</key>
        <true/>
        <key>NSUbiquitousContainerName</key>
        <string>Example App Name</string>
        <key>NSUbiquitousContainerSupportedFolderLevels</key>
        <string>Any</string>
    </dict>
</dict>

我的 AppName.entitlements 文件包含其中:

<key>com.apple.developer.icloud-container-identifiers</key>
<array>
    <string>$(TeamIdentifierPrefix)com.example.AppName</string>
    <string>iCloud.com.example.AppName</string>
</array>
<key>com.apple.developer.icloud-services</key>
<array>
    <string>CloudDocuments</string>
</array>
<key>com.apple.developer.ubiquity-container-identifiers</key>
<array>
    <string>$(TeamIdentifierPrefix)com.example.AppName</string>
</array>

现在我们都设置了访问这两个容器的能力,我将我希望能够访问的 2 个 iCloud 通用地址(旧式 iCloud 文档和更新的 iCloud Drive)添加到我的 Info.plist 中:

<key>UbiquitousContainers</key>
<array>
    <string>$(TeamIdentifierPrefix)com.example.AppName</string>
    <string>iCloud.com.example.AppName</string>
</array>

然后我将以下内容添加到常量文件中以便于访问:

struct UbiquityContainers {
    private static let ubiquityContainers : [String] = Bundle.main.object(forInfoDictionaryKey: "UbiquitousContainers") as! [String]
    static var iCloudDocuments : String {
        get {
            return ubiquityContainers[0]
        }
    }
    static var iCloudDrive : String {
        get {
            return ubiquityContainers[1]
        }
    }
}

我选择允许用户通过 TabBar 在两个容器之间切换。旧的 iCloud 文档目录包含来自我的应用程序的旧版本的文档,这些文档需要在打开之前转换为新的文档格式,因此在我的情况下,为每个文件版本具有单独的视图是有意义的。

var ubiquityContainer : String = UbiquityContainers.iCloudDrive
func tabBar(_ tabBar: UITabBar, didSelect item: UITabBarItem) {
    if(self.documentsInCloud) {
        if(item == self.iCloudDriveTabBarItem) {
            self.ubiquityContainer = UbiquityContainers.iCloudDrive
        } else if(item == self.iCloudDocumentsTabBarItem) {
            self.ubiquityContainer = UbiquityContainers.iCloudDocuments
        }
        self.startCloudQuery()
    }
}

我希望这对将来可能由于卵泡散落在地面上而缺乏卵泡的人有所帮助。:)

于 2018-03-23T08:55:31.723 回答