关于权限相关的文章已经发了不少:iOS开发中的这些权限,你搞懂了吗?、如何获取iOS应用网络权限?、iOS开发中权限再度梳理等,这些文章罗列在一起,多少显得有些啰嗦。
这篇核心是简短介绍一下重构后的开源库: JLAuthorizationManager、JLAuthorizationManager-Swift,这个开源库迭代完成时间是2019.02.12,此后,便将该库集成到了当前项目中使用,目前为止,还算比较稳定,特推荐给老铁~
基本特性
- 覆盖面全,目前支持拍照、相册、蜂窝网络、麦克风、日历、提醒事项、通知、定位、音乐库、语音识别、Siri、蓝牙、健康数据、体能与训练记录等权限访问;
- 使用方法简单,接口统一,单一权限文件分离,避免因添加无用权限导致提交App Store审核不过的问题;
- 异步请求权限,在主线程下回调;
- 提供单例模式下的所有权限访问和单一权限访问的两种方式,便于开发者更加灵活的使用;
单一权限文件的使用JLxxxPermission:
- 基本使用(以请求相册权限为例说明):
OC版本
JLPhotosPermission *permission = [JLPhotosPermission instance];
NSLog(@"current authoriazation status:%@", [self authorizationWithStatus:permission.authorizationStatus]);
NSLog(@"%@添加权限Plist描述", permission.hasSpecificPermissionKeyFromInfoPlist ? @"是" : @"没有");
[permission requestAuthorizationWithCompletion:^(BOOL granted) {
NSLog(@"%@ : %@", [self titleWithType:permission.type], granted ? @"已授权" : @"未授权");
}];
Swift版本:
let permission = PhotosPermission()
print("\(type.title) -> status:\(permission.authorizedStatus())")
permission.requestPermission { granted in
print(granted ? "已授权 -> \(type.title)" : "未授权 -> \(type.title)")
}
- 请求定位、蓝牙等权限时,需要使用其单例方法shared进行调用,以请求定位信息为例说明:
OC版本
JLLocationAlwaysPermission *permission = [JLLocationAlwaysPermission sharedInstance];
NSLog(@"current authoriazation status:%@", [self authorizationWithStatus:permission.authorizationStatus]);
NSLog(@"%@添加权限Plist描述", permission.hasSpecificPermissionKeyFromInfoPlist ? @"是" : @"没有");
[permission requestAuthorizationWithCompletion:^(BOOL granted) {
NSLog(@"%@ : %@", [self titleWithType:permission.type], granted ? @"已授权" : @"未授权");
}];
Swift版本:
let permission = LocationAlwaysPermission.shared
print("\(type.title) -> status:\(permission.authorizedStatus())")
permission.requestPermission { granted in
print(granted ? "已授权 -> \(type.title)" : "未授权 -> \(type.title)")
}
更多细节
- 参照GitHub上文档介绍(中文、英文)或者DEMO中的用法;
- 如您在使用该开源库过程中,遇到一些bug或者需要改进的地方,您可以直接创建issue说明,如您有更好的实现方式,欢迎Pull Request
注意事项
关于该权限库相关更新信息不会再以简书的形式通知更新了,把更新的信息都在微信公众号上通知,感兴趣的可以关注公众号:猿视角(iOSDevSkills)