iOS开发中的这些权限,你搞懂了吗?

写在前面

  • APP开发避免不开系统权限的问题,如何在APP以更加友好的方式向用户展示系统权限,似乎也是开发过程中值得深思的一件事;
  • 那如何提高APP获取iOS系统权限的通过率呢?有以下几种方式:1.在用户打开APP时就向用户请求权限;2.告知用户授权权限后能够获得好处之后,再向用户请求权限;3.在绝对必要的情况下才向用户请求权限,例如:用户访问照片库时请求访问系统相册权限;4.在展示系统权限的对话框前,先向用户显示自定义的对话框,若用户选择不允许,默认无操作,若用户选择允许,再展示系统对话框。
  • 上述情况在开发过程中是经常遇到的,不同方式的选择会影响最后用户交互体验。这一点感悟正是源于上一周工作遇到的问题:适配iOS10,如何获取应用联网权限用以管理系统对话框的显示管理。当我把这个问题解决后,感觉有必要将常用的iOS系统权限做一个总结,以便后用。

权限分类

  • 联网权限
  • 相册权限
  • 相机、麦克风权限
  • 定位权限
  • 推送权限
  • 通讯录权限
  • 日历、备忘录权限

联网权限

  • 引入头文件 @import CoreTelephony;
  • 应用启动后,检测应用中是否有联网权限
    CTCellularData *cellularData = [[CTCellularData alloc]init];
    cellularData.cellularDataRestrictionDidUpdateNotifier =  ^(CTCellularDataRestrictedState state){
      //获取联网状态
      switch (state) {
          case kCTCellularDataRestricted:
              NSLog(@"Restricrted");
              break;
          case kCTCellularDataNotRestricted:
              NSLog(@"Not Restricted");
              break;
          case kCTCellularDataRestrictedStateUnknown:
              NSLog(@"Unknown");
              break;
          default:
              break;
      };
    };
  • 查询应用是否有联网功能
    CTCellularData *cellularData = [[CTCellularData alloc]init];
    CTCellularDataRestrictedState state = cellularData.restrictedState;
     switch (state) {
      case kCTCellularDataRestricted:
          NSLog(@"Restricrted");
          break;
      case kCTCellularDataNotRestricted:
          NSLog(@"Not Restricted");
          break;
      case kCTCellularDataRestrictedStateUnknown:
          NSLog(@"Unknown");
          break;
      default:
          break;
    }

相册权限--iOS 9.0之前

  • 导入头文件@import AssetsLibrary;
  • 检查是否有相册权限
     ALAuthorizationStatus status = [ALAssetsLibrary authorizationStatus];
    switch (status) {
      case ALAuthorizationStatusAuthorized:
          NSLog(@"Authorized");
          break;
      case ALAuthorizationStatusDenied:
          NSLog(@"Denied");
          break;
      case ALAuthorizationStatusNotDetermined:
          NSLog(@"not Determined");
          break;
      case ALAuthorizationStatusRestricted:
          NSLog(@"Restricted");
          break;
    
      default:
          break;
    }

相册权限--iOS 8.0之后

  • 导入头文件@import Photos;
  • 检查是否有相册权限
    PHAuthorizationStatus photoAuthorStatus = [PHPhotoLibrary authorizationStatus];
    switch (photoAuthorStatus) {
      case PHAuthorizationStatusAuthorized:
          NSLog(@"Authorized");
          break;
      case PHAuthorizationStatusDenied:
          NSLog(@"Denied");
          break;
      case PHAuthorizationStatusNotDetermined:
          NSLog(@"not Determined");
          break;
      case PHAuthorizationStatusRestricted:
          NSLog(@"Restricted");
          break;
      default:
          break;
    }
  • ![Uploading 144446-b8aca7ba38c5f8c0_695906.png . . .]获取相册权限
     [PHPhotoLibrary requestAuthorization:^(PHAuthorizationStatus status) {
      if (status == PHAuthorizationStatusAuthorized) {
          NSLog(@"Authorized");
      }else{
          NSLog(@"Denied or Restricted");
      }
      }];

相机和麦克风权限

  • 导入头文件@import AVFoundation;
  • 检查是否有相机或麦克风权限
    AVAuthorizationStatus AVstatus = [AVCaptureDevice authorizationStatusForMediaType:AVMediaTypeVideo];//相机权限
    AVAuthorizationStatus AVstatus = [AVCaptureDevice authorizationStatusForMediaType:AVMediaTypeAudio];//麦克风权限
    
    switch (AVstatus) {
      case AVAuthorizationStatusAuthorized:
          NSLog(@"Authorized");
          break;
      case AVAuthorizationStatusDenied:
          NSLog(@"Denied");
          break;
      case AVAuthorizationStatusNotDetermined:
          NSLog(@"not Determined");
          break;
      case AVAuthorizationStatusRestricted:
          NSLog(@"Restricted");
          break;
      default:
          break;
    }
  • 获取相机或麦克风权限
    [AVCaptureDevice requestAccessForMediaType:AVMediaTypeVideo completionHandler:^(BOOL granted) {//相机权限
      if (granted) {
          NSLog(@"Authorized");
      }else{
          NSLog(@"Denied or Restricted");
      }
    }];
    
    [AVCaptureDevice requestAccessForMediaType:AVMediaTypeAudio completionHandler:^(BOOL granted) {//麦克风权限
      if (granted) {
          NSLog(@"Authorized");
      }else{
          NSLog(@"Denied or Restricted");
      }
    }];

定位权限

  • 导入头文件@import CoreLocation;
  • 由于iOS8.0之后定位方法的改变,需要在info.plist中进行配置;

配置文件

  • 检查是否有定位权限

     BOOL isLocation = [CLLocationManager locationServicesEnabled];
    if (!isLocation) {
      NSLog(@"not turn on the location");
    }
    CLAuthorizationStatus CLstatus = [CLLocationManager authorizationStatus];
    switch (CLstatus) {
      case kCLAuthorizationStatusAuthorizedAlways:
          NSLog(@"Always Authorized");
          break;
      case kCLAuthorizationStatusAuthorizedWhenInUse:
          NSLog(@"AuthorizedWhenInUse");
          break;
      case kCLAuthorizationStatusDenied:
          NSLog(@"Denied");
          break;
      case kCLAuthorizationStatusNotDetermined:
          NSLog(@"not Determined");
          break;
      case kCLAuthorizationStatusRestricted:
          NSLog(@"Restricted");
          break;
      default:
          break;
    }
  • 获取定位权限
    CLLocationManager *manager = [[CLLocationManager alloc] init];
    [manager requestAlwaysAuthorization];//一直获取定位信息
    [manager requestWhenInUseAuthorization];//使用的时候获取定位信息
  • 在代理方法中查看权限是否改变
    - (void)locationManager:(CLLocationManager *)manager didChangeAuthorizationStatus:(CLAuthorizationStatus)status{
     switch (status) {
      case kCLAuthorizationStatusAuthorizedAlways:
          NSLog(@"Always Authorized");
          break;
      case kCLAuthorizationStatusAuthorizedWhenInUse:
          NSLog(@"AuthorizedWhenInUse");
          break;
      case kCLAuthorizationStatusDenied:
          NSLog(@"Denied");
          break;
      case kCLAuthorizationStatusNotDetermined:
          NSLog(@"not Determined");
          break;
      case kCLAuthorizationStatusRestricted:
          NSLog(@"Restricted");
          break;
      default:
          break;
      }
    
    }

推送权限

  • 检查是否有通讯权限

      UIUserNotificationSettings *settings = [[UIApplication sharedApplication] currentUserNotificationSettings];
    switch (settings.types) {
      case UIUserNotificationTypeNone:
          NSLog(@"None");
          break;
      case UIUserNotificationTypeAlert:
          NSLog(@"Alert Notification");
          break;
      case UIUserNotificationTypeBadge:
          NSLog(@"Badge Notification");
          break;
      case UIUserNotificationTypeSound:
          NSLog(@"sound Notification‘");
          break;
    
      default:
          break;
    }
  • 获取推送权限
    UIUserNotificationSettings *setting = [UIUserNotificationSettings settingsForTypes:UIUserNotificationTypeSound | UIUserNotificationTypeAlert | UIUserNotificationTypeBadge categories:nil];
    [[UIApplication sharedApplication] registerUserNotificationSettings:setting];

通讯录权限

iOS9.0之前
  • 导入头文件 @import AddressBook;
  • 检查是否有通讯录权限
     ABAuthorizationStatus ABstatus = ABAddressBookGetAuthorizationStatus();
    switch (ABstatus) {
      case kABAuthorizationStatusAuthorized:
          NSLog(@"Authorized");
          break;
      case kABAuthorizationStatusDenied:
          NSLog(@"Denied‘");
          break;
      case kABAuthorizationStatusNotDetermined:
          NSLog(@"not Determined");
          break;
      case kABAuthorizationStatusRestricted:
          NSLog(@"Restricted");
          break;
      default:
          break;
    }
  • 获取通讯录权限
    ABAddressBookRef addressBook = ABAddressBookCreateWithOptions(NULL, NULL);
    ABAddressBookRequestAccessWithCompletion(addressBook, ^(bool granted, CFErrorRef error) {
      if (granted) {
          NSLog(@"Authorized");
          CFRelease(addressBook);
      }else{
          NSLog(@"Denied or Restricted");
      }
    });
iOS9.0及以后
  • 导入头文件 @import Contacts;
  • 检查是否有通讯录权限
CNAuthorizationStatus status = [CNContactStore authorizationStatusForEntityType:CNEntityTypeContacts];
  switch (status) {
        case CNAuthorizationStatusAuthorized:
        {
            NSLog(@"Authorized:");
        }
            break;
        case CNAuthorizationStatusDenied:{
            NSLog(@"Denied");
        }
            break;
        case CNAuthorizationStatusRestricted:{
            NSLog(@"Restricted");
        }
            break;
        case CNAuthorizationStatusNotDetermined:{
             NSLog(@"NotDetermined");
        }
            break;

       }
  • 获取通讯录权限
CNContactStore *contactStore = [[CNContactStore alloc] init];
    [contactStore requestAccessForEntityType:CNEntityTypeContacts completionHandler:^(BOOL granted, NSError * _Nullable error) {
        if (granted) {

           NSLog(@"Authorized");

        }else{

           NSLog(@"Denied or Restricted");
        }
    }];

日历、备忘录权限

  • 导入头文件
  • 检查是否有日历或者备忘录权限
     typedef NS_ENUM(NSUInteger, EKEntityType) {
      EKEntityTypeEvent,//日历
      EKEntityTypeReminder //备忘
     };
  • EKAuthorizationStatus EKstatus = [EKEventStore  authorizationStatusForEntityType:EKEntityTypeEvent];
    switch (EKstatus) {
      case EKAuthorizationStatusAuthorized:
          NSLog(@"Authorized");
          break;
      case EKAuthorizationStatusDenied:
          NSLog(@"Denied‘");
          break;
      case EKAuthorizationStatusNotDetermined:
          NSLog(@"not Determined");
          break;
      case EKAuthorizationStatusRestricted:
          NSLog(@"Restricted");
          break;
      default:
          break;
    }
  • 获取日历或备忘录权限
    EKEventStore *store = [[EKEventStore alloc]init];
    [store requestAccessToEntityType:EKEntityTypeEvent completion:^(BOOL granted, NSError * _Nullable error) {
      if (granted) {
          NSLog(@"Authorized");
      }else{
          NSLog(@"Denied or Restricted");
      }
    }];

最后一点

  • 素有获取权限的方法,多用于用户第一次操作应用,iOS 8.0之后,将这些设置都整合在一起,并且可以开启或关闭相应的权限。所有的权限都可以通过下面的方法打开:

    [[UIApplication sharedApplication] openURL:[NSURL URLWithString:UIApplicationOpenSettingsURLString]];

上述的权限多为经常用到的权限,当然不会很全面,大家如有需要其他的权限,可以在下方评论,我会及时加上去的。
希望这篇文章能够给大家的开发带来一些便利。
欢迎关注微信公众号ID:iOSDevSkills,或者搜索<攻城狮的动态>,更多精彩技术文章,期待您的加入!一起讨论,一起成长!

更新记录:2016.9.22添加iOS9.0以后访问通讯录权限;

文/Jack_lin(简书作者)
原文链接:http://www.jianshu.com/p/27e57922232b
著作权归作者所有,转载请联系作者获得授权,并标注“简书作者”。

时间: 2024-08-08 01:23:19

iOS开发中的这些权限,你搞懂了吗?的相关文章

再续iOS开发中的这些权限

前言 上篇文章iOS开发中的这些权限,你搞懂了吗?介绍了一些常用权限的获取和请求方法,知道这些方法的使用基本上可以搞定大部分应用的权限访问的需求.但是,这些方法并不全面,不能涵盖住所有权限访问的方法. So,笔者在介绍一下剩下的几种权限的访问方法和一些使用上的注意事项,希望能给大家的开发过程带来一丝便利. 最后,笔者将经常使用的权限请求方法封装开源库JLAuthorizationManager送给大家,欢迎大家pull request 和 star~~ 权限 语音识别: 媒体资料库/Apple

iOS开发中权限再度梳理

前言 上篇文章iOS开发中的这些权限,你搞懂了吗?介绍了一些常用权限的获取和请求方法,知道这些方法的使用基本上可以搞定大部分应用的权限访问的需求.但是,这些方法并不全面,不能涵盖住所有权限访问的方法. So,笔者在介绍一下剩下的几种权限的访问方法和一些使用上的注意事项,希望能给大家的开发过程带来一丝便利. 最后,笔者将经常使用的权限请求方法封装开源库JLAuthorizationManager送给大家,欢迎大家pull request 和 star~~ 权限 语音识别 媒体资料库/Apple M

iOS 开发中用户记住账户,密码

在iOS开发中经常会用到记住账户.密码,以此来提高用户的体验.下面就浅谈一下账户.密码的存储. 一.登录 记录已登录用户步骤,存入偏好设置中存储放入一个数组. 具体存储 1:存储用户到偏好设置中,其中用户是一个数组向服务器响应客户端后的一些操作(如果响应数据成功)其中用户和密码是一一对应的 1.1先从沙盒中偏好设置中读取对应的用户集合 读取用户名: NSMutableArray *AccArys = [NSMutableArray arrayWithArray:[[NSUserDefaults

ios 开发中 动态库 与静态库的区别

使用静态库的好处 1,模块化,分工合作 2,避免少量改动经常导致大量的重复编译连接 3,也可以重用,注意不是共享使用 动态库使用有如下好处: 1使用动态库,可以将最终可执行文件体积缩小 2使用动态库,多个应用程序共享内存中得同一份库文件,节省资源 3使用动态库,可以不重新编译连接可执行程序的前提下,更新动态库文件达到更新应用程序的目的. 从1可以得出,将整个应用程序分模块,团队合作,进行分工,影响比较小. 等其他好处, 从2可以看出,其实动态库应该叫共享库,那么从这个意义上来说,苹果禁止iOS开

iOS开发中 Quartz2D使用详细 简介

1> Quartz2D简介 *  PPT简介 什么是Quartz2D?二维的绘图引擎 什么是二维?平面 什么是引擎?经包装的函数库,方便开发者使用.也就是说苹果帮我们封装了一套绘图的函数库 同时支持iOS和Mac系统什么意思?用Quartz2D写的同一份代码,既可以运行在iphone上又可以运行在mac上,可以跨平台开发. 开发中比较常用的是截屏/裁剪/自定义UI控件. Quartz2D在iOS开发中的价值就是自定义UI控件. 图形上下文的数据类型和作用. 有多少种上下文. 自定义控件的步骤.

ios开发中遇到的问题和解答汇总

如何让一个数组中的字典,如果字典中有重复的id.将重复的id的字典进行数组整合....<点击查看详情>iOS UIView 创建是不是都会经过initWithFrame?<点击查看详情>iPad 9.1系统上键盘响应很慢<点击查看详情>ios如何绑定数据?<点击查看详情>iOS开发,我想上传一个.gsd的文件(或者stl),请问该怎么做<点击查看详情>iOS NSTimer问题<点击查看详情>iOS大部分积分墙软件为啥都做基于Safa

iOS开发中遇到的一些问题及解决方案【转载】

iOS开发中遇到的一些问题及解决方案[转载] 2015-12-29 [385][scrollView不接受点击事件,是因为事件传递失败] // //  MyScrollView.m //  Created by beyond on 15/6/6. //  Copyright (c) 2015年 beyond.com All rights reserved. //  不一定要用继承,可以使用分类 #import "MyScrollView.h" #import "CoView.

iOS开发中的ARC内存管理de技术要点

本文旨在通过简明扼要的方式总结出iOS开发中ARC(Automatic Reference Counting,自动引用计数)内存管理技术的要点,所以不会涉及全部细节.这篇文章不是一篇标准的ARC使用教程,并假定读者已经对ARC有了一定了解和使用经验.详细的关于ARC的信息请参见苹果的官方文档与网上的其他教程:) 本文的主要内容: ARC的本质 ARC的开启与关闭 ARC的修饰符 ARC与Block ARC与Toll-Free Bridging ARC的本质 ARC是编译器(时)特性,而不是运行时

iOS开发中UIPopoverController的使用详解

这篇文章主要介绍了iOS开发中UIPopoverController的使用,代码基于传统的Objective-C,需要的朋友可以参考下 一.简单介绍 1.什么是UIPopoverController 是iPad开发中常见的一种控制器(在iPhone上不允许使用) 跟其他控制器不一样的是,它直接继承自NSObject,并非继承自UIViewController 它只占用部分屏幕空间来呈现信息,而且显示在屏幕的最前面 2.使用步骤 要想显示一个UIPopoverController,需要经过下列步骤