iOS 10、Xcode 8 遇到部分问题解决记录(包括控制台日志不输出)
今天把iphone 6 升级到ios10 后,用Xcode 7进行真机调试的时候提示:
Could not find Developer Disk Image
果断准备升级到Xcode 8 。但是想保留Xcode 7,解决方法:
1、打开Finder,进入“应用程序”文件夹,新建一个文件夹命名为“Xcode 7”。
2、将原来的Xcode7程序拖进刚才创建的文件夹。
3、安装Xcode8之前,首先要把系统升级到10.11.6
4、接下来安装Xcode8。为方便以后升级,把Xcode8直接安装在“应用程序”文件夹内。或者直接通过AppStore下载安装。
5、至此,安装完成。打开Launchpad,可以见到有两个Xcode,且都能正常打开。
6、打开xcodeproj文件时,系统会默认使用Xcode8
升级以后出现的各种问题记录如下:
1、升级到Xcode8 后,真机调试,原来的描述文件出问题了(一堆问题,可能每个人的问题不一样,我就不列举了,反正就是有关描述文件的问题)
发现:Deprecated (如下)
然后:Target - General - 勾选 Xcode8 新增的Automatically manage signing ,
进行team选择等
后面:Target - BuildSeting 就可以如下配置:
通过打包测试,完全没有问题。
2. Xcode8 在 Target - General下有个Signing , Xcode新增的Automatically manage signing会自动管理需要的配置文件和证书。我们只需要在Xcode的Account中登录我们的AppleID账号即可,配置证书变得如此简单.
Provisioning Profile 文件选取,已经从Buiid Settings移动到了General中,Buiid Settings中已经标识了 Deprecated(说白了,可以不用弄了),以前添加设备之后需要重新生成描述文件,然后下载安装,很麻烦,现在省事多了。
当然你也可以选择手动管理配置文件,除此之外,如果签名证书有任何问题Xcode都会及时提示你.
3、一切都配置好了以后,真机调试的时候还是出现以下问题:
The certificate used to sign "你的项目名称" has either expired or has been revoked. An updated certificate is required to sign and install the application.
检查一下,没有问题啊,但是就是报这个错误。
解决:
原来测试证书的p12文件安装了好几次,上次的已经失效,影响了真机调试。在钥匙窜中找到那些失效的证书删掉即可。只留一个有效的证书。
4、升级到Xcode8(ios 10),发现在注册remote notification的,获取device token的时候失败了,错误信息为:
no valid 'aps-environment'
entitlement string found for application
原来在Xcode7中,push notifications开关只有一个步骤:将push notifications加入到app id。
但是Xcode8中,打开push notifications开关有两个步骤:
多了一步写entitlements文件的步骤
所以,用Xcode8打开工程后,应该重新打开一次push notification开关,之后entitlements文件中会多出两行:
<key>aps-environment</key>
<string>development</string>
有了这两行之后,才可以正常注册device token。
使用:codesign --display --entitlements :- ./myApp.app
命令,可以看到app文件内的entitlement。
经发现:如果用production证书签名,可以看到:
<key>aps-environment</key>
<string>production</string>
说明苹果在签名过程中,会自动更新aps-environment
字段。
5、IDFA可被用户禁用
iOS10中,用户可以在设置-隐私-广告-限制广告追踪中禁止app读取IDFA,这时app读取到的IDFA就是一串0。
官方文档中这样说:
In iOS 10.0 and later, the value of advertisingIdentifier is all zeroes when the user has limited ad tracking.
6、Info.plist增加权限字段
使用Xcode8构建的app,在使用相册等系统权限时会崩溃。错误信息为:
This app has crashed because it attempted to access privacy-sensitive data without a usage description. The app's Info.plist must contain an NSPhotoLibraryUsageDescription key with a string value explaining to the user how the app uses this data.
官方文档中解释:
Important: To protect user privacy, an iOS app linked on or after iOS 10.0, and which accesses the user’s photo library, must statically declare the intent to do so. Include the NSPhotoLibraryUsageDescription key in your app’s Info.plist file and provide a purpose string for this key. If your app attempts to access the user’s photo library without a corresponding purpose string, your app exits.
必须在Info.plist文件中增加NSPhotoLibraryUsageDescription键,并且填入合适的描述文本
还有很多其他的权限,如相机等,也需要在Info.plist文件中声明,具体可参考官方文档。
有一个坑就是,如果string的值为空,这行权限的声明就会无效,遇到的时候还是崩溃:
<key>NSPhotoLibraryUsageDescription</key>
<string></string>
7、UITableView、UICollectionView生命周期适配
WWDC介绍了UITableView
和UICollectionView
的生命周期在iOS10中发生了改变。
在iOS9及之前,一个UICollectionViewCell
被重用的过程是这样的:
- 一个cell即将出现的屏幕上
- prepareForReuse
- cellForItemAtIndexPath
- willDisplayCell
- ……
- 一个cell完全离开屏幕
- didEndDisplayCell
- 进入reuse queue
但在iOS10中,一个UICollectionViewCell被重用的过程变成了这样:
- 一个cell还没出现在屏幕上
- prepareForReuse
- cellForItemAtIndexPath
- 一个cell即将出现的屏幕上
- ……
- 一个cell完全离开屏幕
- didEndDisplayCell
- 一段时间后再进入reuse queue
所以,iOS10后,cellForItemAtIndexPath
被调用时,并不表示这个cell即将要出现在了屏幕上。还是得老老实实使用willDisplayCell
和didEndDisplayCell
方法。
8、控制台日志不打印问题设置
Edit Scheme -> Run -> Arguments, 在Environment Variables里边添加 OS_ACTIVITY_MODE =disable 添加完后并选中,控制台打印日志不输出。同时取消后,日志打印输出。