作者:金田
iOS系統版本的不斷升級的前提,伴隨著用戶使用設備的安全性提升,iOS系統對于App需要使用的硬件限制也越來越嚴格,App處理稍有不妥,輕則造成功能不可用用戶還不知道,重則會造成App Crash。
當用戶在App啟動時,看到彈出來的一條條“XXX 請求訪問您的位置” “XXX 請求訪問您的通訊錄” “XXX 請求訪問您的日歷” “XXX 請求訪問您的攝像頭” 等一系列消息時,用戶覺得不耐煩的同時,也會由于一時的安全考慮而把相應的功能給屏蔽掉,這還只是開始,當用戶真正在使用對應功能的時候,就會出現一連續的奇怪現象,比如數據顯示異常:明明通訊錄里面有信息,卻總是加載不出數據;有的甚至是直接Crash。
下面,筆者將會綜合性地把上述硬件的授權檢測,一一地詳細列出,并給出相關示例代碼:
1、定位服務
檢測方法
+ (CLAuthorizationStatus)authorizationStatus
相關返回參數
//用戶尚未做出選擇
kCLAuthorizationStatusNotDetermined = 0,
// 未授權,且用戶無法更新,如家長控制情況下
kCLAuthorizationStatusRestricted,
// 用戶拒絕App使用
kCLAuthorizationStatusDenied,
// 總是使用
kCLAuthorizationStatusAuthorizedAlways NS_ENUM_AVAILABLE(NA, 8_0),
// 按需使用
kCLAuthorizationStatusAuthorizedWhenInUse NS_ENUM_AVAILABLE(NA, 8_0),
// 已授權
kCLAuthorizationStatusAuthorized
參考代碼
__block void (^checkLocationAuth)(void) = ^{
CLAuthorizationStatus authStatus = [CLLocationManager authorizationStatus];
if (CLAuthorizationStatusAuthorized == authStatus) {
//授權成功,執行后續操作
}else {
dispatch_after(dispatch_time(DISPATCH_TIME_NOW, (int64_t)(0.5 * NSEC_PER_SEC)), dispatch_get_main_queue(), ^{
checkLocationAuth();
});
}
};
checkLocationAuth();
2、通訊錄
檢測方法
ABAuthorizationStatus ABAddressBookGetAuthorizationStatus(void)
授權狀態
kABAuthorizationStatusNotDetermined = 0, // 未進行授權選擇
kABAuthorizationStatusRestricted, // 未授權,且用戶無法更新,如家長控制情況下
kABAuthorizationStatusDenied, // 用戶拒絕App使用
kABAuthorizationStatusAuthorized // 已授權,可使用
參考代碼
__block void (^checkAddressBookAuth)(void) = ^{
ABAuthorizationStatus authStatus = ABAddressBookGetAuthorizationStatus();
if (kABAuthorizationStatusAuthorized == authStatus) {
//授權成功,執行后續操作
}else {
dispatch_after(dispatch_time(DISPATCH_TIME_NOW, (int64_t)(0.5 * NSEC_PER_SEC)), dispatch_get_main_queue(), ^{
checkAddressBookAuth();
});
}
};
checkAddressBookAuth();
3、日歷/提醒事項授權
檢測方法
+ (EKAuthorizationStatus)authorizationStatusForEntityType:(EKEntityType)entityType
參數類型
EKEntityTypeEvent, //事件
EKEntityTypeReminder//提醒
授權狀態
EKAuthorizationStatusNotDetermined = 0,// 未進行授權選擇
EKAuthorizationStatusRestricted, // 未授權,且用戶無法更新,如家長控制情況下
EKAuthorizationStatusDenied, // 用戶拒絕App使用
EKAuthorizationStatusAuthorized, // 已授權,可使用
參考代碼
__block void (^checkCalanderAuth)(void) = ^{
EKAuthorizationStatus authStatus = [EKAuthorizationStatus authorizationStatusForEntityType:EKEntityTypeEvent];
if (EKAuthorizationStatusAuthorized == authStatus) {
//授權成功,執行后續操作
}else {
dispatch_after(dispatch_time(DISPATCH_TIME_NOW, (int64_t)(0.5 * NSEC_PER_SEC)), dispatch_get_main_queue(), ^{
checkCalanderAuth();
});
}
};
checkCalanderAuth();
4、照片庫授權
檢測方法
+ (ALAuthorizationStatus)authorizationStatus;
授權狀態
ALAuthorizationStatusNotDetermined = 0,// 未進行授權選擇
ALAuthorizationStatusRestricted, // 未授權,且用戶無法更新,如家長控制情況下
ALAuthorizationStatusDenied, // 用戶拒絕App使用
ALAuthorizationStatusAuthorized, // 已授權,可使用
參考代碼
__block void (^checkAssetLibraryAuth)(void) = ^{
ALAuthorizationStatus authStatus = [ALAuthorizationStatus authorizationStatus];
if (ALAuthorizationStatusAuthorized == authStatus) {
//授權成功,執行后續操作
}else {
dispatch_after(dispatch_time(DISPATCH_TIME_NOW, (int64_t)(0.5 * NSEC_PER_SEC)), dispatch_get_main_queue(), ^{
checkAssetLibraryAuth();
});
}
};
checkAssetLibraryAuth();
5、藍牙授權狀態檢測
檢測方法
+ (CBPeripheralManagerAuthorizationStatus)authorizationStatus;
授權狀態
CBPeripheralManagerAuthorizationStatusNotDetermined = 0,// 未進行授權選擇
CBPeripheralManagerAuthorizationStatusRestricted, // 未授權,且用戶無法更新,如家長控制情況下
CBPeripheralManagerAuthorizationStatusDenied, // 用戶拒絕App使用
CBPeripheralManagerAuthorizationStatusAuthorized, // 已授權,可使用
參考代碼
__block void (^checkPeripheralAuth)(void) = ^{
CBPeripheralManagerAuthorizationStatus authStatus = [CBPeripheralManagerAuthorizationStatus authorizationStatus];
if (CBPeripheralManagerAuthorizationStatusAuthorized == authStatus) {
//授權成功,執行后續操作
}else {
dispatch_after(dispatch_time(DISPATCH_TIME_NOW, (int64_t)(0.5 * NSEC_PER_SEC)), dispatch_get_main_queue(), ^{
checkPeripheralAuth();
});
}
};
checkPeripheralAuth();
6、攝像頭授權狀態檢測
檢測方法
+ (AVAuthorizationStatus)authorizationStatusForMediaType:(NSString *)mediaType;
授權狀態
AVAuthorizationStatusNotDetermined = 0,// 未進行授權選擇
AVAuthorizationStatusRestricted, // 未授權,且用戶無法更新,如家長控制情況下
AVAuthorizationStatusDenied, // 用戶拒絕App使用
AVAuthorizationStatusAuthorized, // 已授權,可使用
參考代碼
__block void (^checkCameraAuth)(void) = ^{
AVAuthorizationStatus authStatus = [AVAuthorizationStatus authorizationStatusForMediaType:AVMediaTypeVideo];
if (AVAuthorizationStatusAuthorized == authStatus) {
//授權成功,執行后續操作
}else {
dispatch_after(dispatch_time(DISPATCH_TIME_NOW, (int64_t)(0.5 * NSEC_PER_SEC)), dispatch_get_main_queue(), ^{
checkCameraAuth();
});
}
};
checkCameraAuth();
7、麥克風授權狀態檢測
檢測方法
- (AVAudioSessionRecordPermission)recordPermission;
授權狀態
AVAudioSessionRecordPermissionUndetermined, // 用戶尚未被請求許可。
AVAudioSessionRecordPermissionDenied, // 用戶已被要求并已拒絕許可。
AVAudioSessionRecordPermissionGranted, // 用戶已被要求并已授予權限。
參考代碼
__block void (^checkRecordPermission)(void) = ^{
AVAudioSessionRecordPermission authStatus = [[AVAudioSession sharedInstance] recordPermission];
if (AVAudioSessionRecordPermissionGranted == authStatus) {
//授權成功,執行后續操作
}else {
dispatch_after(dispatch_time(DISPATCH_TIME_NOW, (int64_t)(0.5 * NSEC_PER_SEC)), dispatch_get_main_queue(), ^{
checkRecordPermission();
});
}
};
checkRecordPermission();