#pragma mark - 摄像头权限
+(BOOL)checkCameraAuthority;
+(void)cameraAuthorityCheckSuccess:(AuthorizedFinishBlock)_success fail:(AuthorizedFinishBlock)_fail;
#pragma mark - 麦克风权限
+(BOOL)checkAudioAuthority;
+(void)audioAuthorityCheckSuccess:(AuthorizedFinishBlock)_success fail:(AuthorizedFinishBlock)_fail;
#pragma mark - 相册权限
+(BOOL)checkAlbumAuthority;
+(void)albumAuthorityCheckSuccess:(AuthorizedFinishBlock)_success fail:(AuthorizedFinishBlock)_fail;
#pragma mark - 推送通知权限
+(BOOL)checkPushNotificationAuthority;
+(void)pushNotificationAuthorityCheckSuccess:(AuthorizedFinishBlock)_success fail:(AuthorizedFinishBlock)_fail;
#pragma mark - 推送通知权限
+(BOOL)checkLocationAuthority;
+(void)locationAuthorityCheckSuccess:(AuthorizedFinishBlock)_success fail:(AuthorizedFinishBlock)_fail;
#pragma mark - 通讯录权限
+(BOOL)checkAddressBookAuthority;
+(void)AddressBookAuthorityCheckSuccess:(AuthorizedFinishBlock)_success fail:(AuthorizedFinishBlock)_fail;
下面是.m文件
里面引入了很多库文件,也不是所用项目都会用到的,用不到的注掉就好。
#import "LYAuthorizedMaster.h"
#import //摄像头麦克风 必须
#import //相册权限
#import //位置权限
#import //通讯录权限
#import "AppDelegate.h"
#define kAPPName [[[NSBundle mainBundle] infoDictionary] objectForKey:@"CFBundleName"]
@implementation LYAuthorizedMaster
#pragma mark -
+(BOOL)checkAuthority:(AVAuthorizationStatus)_status{
return (_status == AVAuthorizationStatusAuthorized) || (_status == AVAuthorizationStatusNotDetermined);
+(void)showAlertController:(AuthorizedFinishBlock)_block device:(NSString *)_device{
UIAlertController *_alertC = [UIAlertController alertControllerWithTitle:@"没有权限" message:[NSString stringWithFormat:@"请开启‘%@’对 %@ 的使用权限",kAPPName,_device] preferredStyle:UIAlertControllerStyleAlert];
[_alertC addAction:[UIAlertAction actionWithTitle:@"取消" style:UIAlertActionStyleCancel handler:nil]];
[_alertC addAction:[UIAlertAction actionWithTitle:@"确定" style:UIAlertActionStyleDefault handler:^(UIAlertAction *action) {
[[UIApplication sharedApplication] openURL:[NSURL URLWithString:UIApplicationOpenSettingsURLString]];
[((AppDelegate *)[UIApplication sharedApplication].delegate).window.rootViewController presentViewController:_alertC animated:YES completion:_block];
#pragma mark - 摄像头权限
+(BOOL)checkCameraAuthority{
return [self checkAuthority:[AVCaptureDevice authorizationStatusForMediaType:AVMediaTypeVideo]];
+(void)cameraAuthorityCheckSuccess:(AuthorizedFinishBlock)_success fail:(AuthorizedFinishBlock)_fail;{
if ([self checkCameraAuthority]) {
if (_success) {
_success();
}else{
[self showAlertController:_fail device:@"相机"];
#pragma mark - 麦克风权限
+(BOOL)checkAudioAuthority{
return [self checkAuthority:[AVCaptureDevice authorizationStatusForMediaType:AVMediaTypeAudio]];
+(void)audioAuthorityCheckSuccess:(AuthorizedFinishBlock)_success fail:(AuthorizedFinishBlock)_fail{
if ([self checkAudioAuthority]) {
if (_success) {
_success();
}else{
[self showAlertController:_fail device:@"麦克风"];
#pragma mark - 相册权限
+(BOOL)checkAlbumAuthority{
return [ALAssetsLibrary authorizationStatus] == ALAuthorizationStatusAuthorized;
+(void)albumAuthorityCheckSuccess:(AuthorizedFinishBlock)_success fail:(AuthorizedFinishBlock)_fail;
if ([self checkAlbumAuthority]) {
if (_success) {
_success();
}else{
[self showAlertController:_fail device:@"照片"];
#pragma mark - 位置权限
+(BOOL)checkLocationAuthority {
return [CLLocationManager locationServicesEnabled];
+(void)locationAuthorityCheckSuccess:(AuthorizedFinishBlock)_success fail:(AuthorizedFinishBlock)_fail{
if ([self checkLocationAuthority]) {
if (_success) {
_success();
}else{
[self showAlertController:_fail device:@"位置"];
#pragma mark - 推送通知权限
+(BOOL)checkPushNotificationAuthority {
return [[UIApplication sharedApplication] currentUserNotificationSettings].types != UIUserNotificationTypeNone;
+(void)pushNotificationAuthorityCheckSuccess:(AuthorizedFinishBlock)_success fail:(AuthorizedFinishBlock)_fail{
if ([self checkAlbumAuthority]) {
if (_success) {
_success();
}else{
[self showAlertController:_fail device:@"通知"];
#pragma mark - 通讯录权限
+(BOOL)checkAddressBookAuthority {
return ABAddressBookGetAuthorizationStatus() == kABAuthorizationStatusAuthorized || ABAddressBookGetAuthorizationStatus() == kABAuthorizationStatusNotDetermined;
+(void)AddressBookAuthorityCheckSuccess:(AuthorizedFinishBlock)_success fail:(AuthorizedFinishBlock)_fail{
if ([self checkAddressBookAuthority]) {
if (_success) {
_success();
}else{
[self showAlertController:_fail device:@"通讯录"];
最后有些时会遇到不弹出权限提示,或需要在提示框增加详细描述的时候,需要手动在info.plist加一些字段。
NSLocationWhenInUseUsageDescription 位置权限 使用期间 状态
NSLocationAlwaysUsageDescription 位置权限 始终 状态
下面这些我并没有都试,所以也不知道是否正确....
NSLocationUsageDescription 用于访问位置权限
NSCalendarsUsageDescription 用于访问日历权限
NSContactsUsageDescription 用于访问联络人
NSPhotoLibraryUsageDescription 用于访问相册
NSRemindersUsageDescription 用于访问提醒
ios应用无法像安卓应用那样直接从自己的服务器下载app安装而无需进行额外的设置,ios的安装要相对复杂一些。
ios的安装,是根据苹果开发者账号类型,根据证书和证书profile文件的不同,安装方法都有所不同的。主要是下面三种安装方法
appuploader iOS 应用自动发布
【摘要】 appuploader是一款专门为 iOS 和 Android 开发人员设计的自动化工具,可以帮助开发人员轻松解决一些繁琐的任务,例如生成屏幕截图、处理配置文件和发布应用程序等。这个工具可以让开发人员在不同的环境下自定义和运行发布管道,使得整个应用的发布过程更加简单和自动化。使用appuploader,开发人员可以避免手动执行这些任务所需的大量时间和精力。这个工具可以自动处理各种细节,例如生...
iOS 应用发布 ITMS-90704 错误解决
今天第一次用 XCode 9 GM 版打包上传应用。貌似上传的过程更简单了。选择 “Automatically manage signing” (自动管理签名)
如何使用 Xcode 打包导出 IPA 文件并进行 iOS 应用内测,无需支付苹果开发者账号费用?
苹果开发者账号认证需要支付 688 元,对于初学 iOS 开发的同学来说,仅仅是为了进行内测而不需要上架 App Store,这样的费用是不必要的。
上传 iOS 应用变得更加容易 - 在 Windows 上架 iOS APP 的工具介绍
随着 Xcode 的更新,苹果公司已经不直接提供 Application Loader 这个工具上传 IPA 了,这对于开发者来说意味着上传 ipa 的过程变得更加困难了。
appuploader iOS 应用自动发布
appuploader是一款专门为 iOS 和 Android 开发人员设计的自动化工具,可以帮助开发人员轻松解决一些繁琐的任务,例如生成屏幕截图、处理配置文件和发布应用程序等。这个工具可以让开发人员在不同的环境下自定义和运行发布管道,使得整个应用的发布过程更加简单和自动化。
iOS应用发布ITMS-90704错误解决
今天第一次用XCode 9 GM版打包上传应用。貌似上传的过程更简单了。选择 “Automatically manage signing” (自动管理签名)后它就直接显示一个汇总信息列表,然后开始上传了,比以前简化了一两个步骤。
iOS 16.1 正式版发布,苹果 App Store 上架首批支持“实时活动”应用
10 月 25 日消息,今天苹果发布了 iOS 16.1 正式版,苹果 App Store 介绍了 iOS 16 新功能尝鲜,包括锁定屏幕、实时活动,以及更多精彩。苹果精选了一些用户可能会喜欢的内容,搭配相得益彰的 App 和游戏,供一览为快。