Xcode15升级Flutter适配隐私清单

背景

Apple于2023年12月07号官方列出了需要隐私清单和签名的三方SDK,从2024年春季开始,在App Store Connect中提交包含这些SDK的应用,必须包含相应的隐私清单。在使用列出的SDK作为二进制依赖项的情况下,也需要提供签名。对于列出的SDK的任何版本,以及对这些列表上SDK进行重新打包的任何SDK,都适用此要求。3月份Apple会将未在隐私清单中提供原因的API通过邮件通知,5月1号以后则会强制要求


面对这样的要求,我们只能乖乖适配了,毕竟听话才不容易被干掉

三方SDK列表

很多常用的库都在列表上,比如AFNetWorking Alamofire SDWebImage...,所以几乎所有的App都需要适配,做过Flutter开发的同学会发现,Flutter也挂在名单上,包括url_launcher path_provider fluttertoast ..., 看来苹果还是忍不住对Flutter 动手了

以上列出是三方库和插件,需要适配添加xcprivacy并说明使用原因。

xcprivacy

xcode15 可以新增App Privacy文件

xcprivacy文件主要包含四项内容

js 复制代码
 Privacy Tracking Enabled 是否开启隐私跟踪
 Privacy Tracking Domains 跟踪域名
 Privacy Nutrition Label Types  隐私营养标签,添加后,打包后生成的PDF文件中
 Privacy Accessed API Types 使用的隐私API及原因说明

官方列出了以下四种类型的API,每种类型API都包含隐私相关的具体API,如果调用了对应的API,需要在隐私清单中列出使用原因,但是目前列表中的三方SDK

可以通过脚本扫描工程中是否使用上述API,并根据扫描结果添加对应的使用原因

扫描脚本

js 复制代码
    cd /Users/xxx/xxx/demo_project
    sh /Users/xxx/xxx/check_xcprivacy.sh
    请输入必要理由api的文件路径:

根据筛选内容添加必要的 NSPrivacyAccessedAPITypes, 提交testflight以后,官方会扫描提交的ipa,并对未声明原因的API发送邮件,可以根据邮件添加对应原因

SDK签名

官方为了保障SDK的可追溯性,提出了SDK签名,签名后的framework和xcframework 对出现_CodeSignature文件,只有xcframework签名后在xcode中查看到签名密钥 要求使用了三方SDK的二进制引用或封装,需要对SDK做签名处理,当然苹果也鼓励所有的SDK做签名处理来保障SDK的安全溯源

js 复制代码
codesign --timestamp -v --sign "Apple Distribution: Truck to Table (UA527FUGW7)" BirdFeeder.xcframework

Flutter适配

flutter需要升级到包含xcprivacy的版本,目前最高版本是3.19.3, 如果将flutter以二进制的形式依赖,需要对flutter.framework做签名

path_provider

sqflite

部分插件已经添加了xcprivacy,需要升级对应的版本

编译问题

在xcode升级后遇到的一些编译的问题,其他问题可以自己查找

  1. xxxx duplicate symbols

Other Linker Flags 添加 -ld64

  1. Symbol not found: '/System/Library/Frameworks/Network.framework/Network'

添加 Network.framework 选择Optional

3. Flutter/Flutter.h

gem install cocoapods -v 1.13.0 -V

总结

目前各方适配的隐私清单xcprivacy 大多数都只添加文件没有添加原因,官方也没有给出具体的添加说明和示例,添加原因后提交testflight会提示邮件,根据邮件内容对api作出说明,没有绝对的安全,只有绝对的安全努力。

参考

www.wwdcnotes.com/notes/wwdc2...

相关推荐
1024小神9 小时前
theos工具来编译xcode的swiftUI项目为ipa文件
macos·swiftui·xcode
watersink19 小时前
基于大模型的pc版语音对话问答
ide·macos·xcode
Macle_Chen2 天前
XCode中使用MonkeyDev开发iOS版的Comand-line Tool的daemon程序
macos·ios·xcode·逆向·comand-line
1024小神7 天前
xcode中移除安装的package dependency
xcode
越甲八千8 天前
python 中match...case 和 C switch case区别
c语言·python·xcode
小画家~12 天前
第八:在Go语言项目中使用Zap日志库
ios·golang·xcode
CocoaKier14 天前
Xcode16踩坑:UIApplication.openURL(_:)方法已彻底废弃
ios·xcode·apple
#摩斯先生14 天前
IOS Xcode Could not find a storyboard named ‘Main‘ in bundle NSBundle
macos·ios·xcode
mlibai15 天前
适配iOS 18:检测并移除三方库中的 bitcode 部分
ios·xcode
Cao_Shixin攻城狮15 天前
Flutter项目升级Xcode 16.2之后编译问题
flutter·xcode