android开发权限询问的示例代码

现在基于信息安全问题,特别是版本是23以上权限越严格。

特别是拍照,读,写权限

一般权限允许过,下次就不用询问了的,所以很多应用都喜欢在首页或者启动页直接询问,不允许的就用不了1、下面给出封装好的类,至于什么时候调看项目需要

public class EasyPermissions {

private static final String TAG = "EasyPermissions";

public interface PermissionCallbacks extends
    ActivityCompat.OnRequestPermissionsResultCallback {

  void onPermissionsGranted(List<String> perms);

  void onPermissionsDenied(List<String> perms);

}

/**
 * Check if the calling context has a set of permissions.
 *
 * @param context the calling context.
 * @param perms  one ore more permissions, such as {@code android.Manifest.permission.CAMERA}.
 * @return true if all permissions are already granted, false if at least one permission
 * is not yet granted.
 */
public static boolean hasPermissions(Context context, String... perms) {
  for (String perm : perms) {
    boolean hasPerm = (ContextCompat.checkSelfPermission(context, perm) == PackageManager.PERMISSION_GRANTED);
    if (!hasPerm) {
      return false;
    }
  }

  return true;
}

/**
 * Request a set of permissions, showing rationale if the system requests it.
 *
 * @param object   Activity or Fragment requesting permissions. Should implement
 *          {@link ActivityCompat.OnRequestPermissionsResultCallback}
 *          or
 *          {@link android.support.v13.app.FragmentCompat.OnRequestPermissionsResultCallback}
 * @param rationale  a message explaining why the application needs this set of permissions, will
 *          be displayed if the user rejects the request the first time.
 * @param requestCode request code to track this request, must be < 256.
 * @param perms    a set of permissions to be requested.
 */
public static void requestPermissions(final Object object, String rationale,
    final int requestCode, final String... perms) {
  requestPermissions(object, rationale,
      android.R.string.ok,
      android.R.string.cancel,
      requestCode, perms);
}

/**
 * Request a set of permissions, showing rationale if the system requests it.
 *
 * @param object     Activity or Fragment requesting permissions. Should implement
 *            {@link ActivityCompat.OnRequestPermissionsResultCallback}
 *            or
 *            {@link android.support.v13.app.FragmentCompat.OnRequestPermissionsResultCallback}
 * @param rationale   a message explaining why the application needs this set of permissions, will
 *            be displayed if the user rejects the request the first time.
 * @param positiveButton custom text for positive button
 * @param negativeButton custom text for negative button
 * @param requestCode  request code to track this request, must be < 256.
 * @param perms     a set of permissions to be requested.
 */
public static void requestPermissions(final Object object, String rationale,
    @StringRes int positiveButton,
    @StringRes int negativeButton,
    final int requestCode, final String... perms) {

  checkCallingObjectSuitability(object);

  boolean shouldShowRationale = false;
  for (String perm : perms) {
    shouldShowRationale = shouldShowRationale || shouldShowRequestPermissionRationale(object, perm);
  }

  if (shouldShowRationale) {
    //弹框询问
    AlertDialog dialog = new AlertDialog.Builder(getActivity(object))
        .setMessage(rationale)
        .setPositiveButton(positiveButton, new DialogInterface.OnClickListener() {
          @Override
          public void onClick(DialogInterface dialog, int which) {
            executePermissionsRequest(object, perms, requestCode);
          }
        })
        .setNegativeButton(negativeButton, new DialogInterface.OnClickListener() {
          @Override
          public void onClick(DialogInterface dialog, int which) {
            // Do nothing, user does not want to request
            PermissionCallbacks callbacks = (PermissionCallbacks) object;
            if(callbacks != null) {
              callbacks.onPermissionsDenied(new ArrayList<String>());
            }
          }
        }).create();
    dialog.show();
  } else {
    executePermissionsRequest(object, perms, requestCode);
  }
}

/**
 * Handle the result of a permission request, should be called from the calling Activity's
 * {@link ActivityCompat.OnRequestPermissionsResultCallback#onRequestPermissionsResult(int, String[], int[])}
 * method.
 * <p/>
 * If any permissions were granted or denied, the Activity will receive the appropriate
 * callbacks through {@link PermissionCallbacks} and methods annotated with
 * {@link AfterPermissionGranted} will be run if appropriate.
 *
 * @param requestCode requestCode argument to permission result callback.
 * @param permissions permissions argument to permission result callback.
 * @param grantResults grantResults argument to permission result callback.
 * @param object    the calling Activity or Fragment.
 * @throws IllegalArgumentException if the calling Activity does not implement
 *                 {@link PermissionCallbacks}.
 */
public static void onRequestPermissionsResult(int requestCode, String[] permissions,
    int[] grantResults, Object object) {

  checkCallingObjectSuitability(object);
  PermissionCallbacks callbacks = (PermissionCallbacks) object;

  // Make a collection of granted and denied permissions from the request.
  ArrayList<String> granted = new ArrayList<>();
  ArrayList<String> denied = new ArrayList<>();
  for (int i = 0; i < permissions.length; i++) {
    String perm = permissions[i];
    if (grantResults[i] == PackageManager.PERMISSION_GRANTED) {
      granted.add(perm);
    } else {
      denied.add(perm);
    }
  }

  // Report granted permissions, if any.
  if (!granted.isEmpty()) {
    // Notify callbacks
    callbacks.onPermissionsGranted(granted);
  }

  // Report denied permissions, if any.
  if (!denied.isEmpty()) {
    callbacks.onPermissionsDenied(denied);
  }

  // If 100% successful, call annotated methods
  if (!granted.isEmpty() && denied.isEmpty()) {
    runAnnotatedMethods(object, requestCode);
  }
}

private static boolean shouldShowRequestPermissionRationale(Object object, String perm) {
  if (object instanceof Activity) {
    return ActivityCompat.shouldShowRequestPermissionRationale((Activity) object, perm);
  } else if (object instanceof Fragment) {
    return ((Fragment) object).shouldShowRequestPermissionRationale(perm);
  } else {
    return false;
  }
}

private static void executePermissionsRequest(Object object, String[] perms, int requestCode) {
  checkCallingObjectSuitability(object);

  if (object instanceof Activity) {
    ActivityCompat.requestPermissions((Activity) object, perms, requestCode);
  } else if (object instanceof Fragment) {
    ((Fragment) object).requestPermissions(perms, requestCode);
  }
}

private static Activity getActivity(Object object) {
  if (object instanceof Activity) {
    return ((Activity) object);
  } else if (object instanceof Fragment) {
    return ((Fragment) object).getActivity();
  } else {
    return null;
  }
}

private static void runAnnotatedMethods(Object object, int requestCode) {
  Class clazz = object.getClass();
  for (Method method : clazz.getDeclaredMethods()) {
    if (method.isAnnotationPresent(AfterPermissionGranted.class)) {
      // Check for annotated methods with matching request code.
      AfterPermissionGranted ann = method.getAnnotation(AfterPermissionGranted.class);
      if (ann.value() == requestCode) {
        // Method must be void so that we can invoke it
        if (method.getParameterTypes().length > 0) {
          throw new RuntimeException("Cannot execute non-void method " + method.getName());
        }

        try {
          // Make method accessible if private
          if (!method.isAccessible()) {
            method.setAccessible(true);
          }
          method.invoke(object);
        } catch (IllegalAccessException e) {
          ILogger.e(TAG, "runDefaultMethod:IllegalAccessException", e);
        } catch (InvocationTargetException e) {
          ILogger.e(TAG, "runDefaultMethod:InvocationTargetException", e);
        }
      }
    }
  }
}

private static void checkCallingObjectSuitability(Object object) {
  // Make sure Object is an Activity or Fragment
  if (!((object instanceof Fragment) || (object instanceof Activity))) {
    throw new IllegalArgumentException("Caller must be an Activity or a Fragment.");
  }

  // Make sure Object implements callbacks
  if (!(object instanceof PermissionCallbacks)) {
    throw new IllegalArgumentException("Caller must implement PermissionCallbacks.");
  }
}}

注:这个类不是我写的,分享给大家

2、调用示例(activity或fragment):(方法调用的时机随你)

private void requestGalleryPermission() {
  //权限参数可以添加很多,不固定参数的
  if (EasyPermissions.hasPermissions(this, Manifest.permission.READ_EXTERNAL_STORAGE,Manifest.permission.WRITE_EXTERNAL_STORAGE)) {
    getPhotos();//如果具有权限做的操作
  } else {
    // Ask for one permission
    EasyPermissions.requestPermissions(this, getString(R.string.permissions_tips_gallery),
        GalleryFinal.PERMISSIONS_CODE_GALLERY, Manifest.permission.READ_EXTERNAL_STORAGE,Manifest.permission.WRITE_EXTERNAL_STORAGE);
  }
}

3、拒绝和允许做的操作(activity或fragment):

@Override
public void onPermissionsGranted(List<String> list) {
  //允许
  getPhotos();
}

@Override
public void onPermissionsDenied(List<String> list) {
  //拒绝
  mTvEmptyView.setText(R.string.permissions_denied_tips);
  //mIvTakePhoto.setVisibility(View.GONE);
}

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持我们。

您可能感兴趣的文章:

  • Android 操作系统获取Root权限 原理详细解析
  • Android获取ROOT权限的实例代码
  • Android点亮屏幕或屏幕解锁和锁定以及其他相关权限实现代码
  • Android uses-permission权限列表中文注释版
  • Android权限操作之uses-permission详解
  • 详解Android权限管理之Android 6.0运行时权限及解决办法
  • Android权限控制之自定义权限
  • Android中Root权限获取的简单代码
  • Android6.0动态申请权限所遇到的问题小结
(0)

相关推荐

  • Android 操作系统获取Root权限 原理详细解析

    android root权限破解分析 许多机友新购来的Android机器没有破解过Root权限,无法使用一些需要高权限的软件,以及进行一些高权限的操作,其实破解手机Root权限是比较简单及安全的,破解Root权限的原理就是在手机的/system/bin/或/system/xbin/目录下放置一个可执行文件"su",这是一个二进制文件,相当于电脑上的exe文件,仅仅在系统中置入这个"su"文件是不会给手机的软件或硬件造成任何故障. 下面的代码是android系统原版的

  • Android获取ROOT权限的实例代码

    获取Android的ROOT权限其实很简单,只要在Runtime下执行命令"su"就可以了. 复制代码 代码如下: // 获取ROOT权限public void get_root(){ if (is_root()){        Toast.makeText(mCtx, "已经具有ROOT权限!", Toast.LENGTH_LONG).show();    }    else{        try{            progress_dialog = P

  • Android6.0动态申请权限所遇到的问题小结

    白天在做SDK23版本的适配,遇到了不少坑,现在抽空记下来,以此为戒. 首先要知道哪些坑,就得先了解一些定义和基本使用方式. 那么先介绍一下动态申请的权限分组情况. 下面的权限组是由谷歌官方定义的,目的是在申请权限时,只要用户允许同一权限组的任意一条权限,那么该组的其他权限也就默认是允许的.不过据高人介绍,在使用时最好是用到哪个权限就具体的请求该权限,因为保不齐哪天谷歌一高兴就把权限组换了甚至删了 group:android.permission-group.CONTACTS permissio

  • Android点亮屏幕或屏幕解锁和锁定以及其他相关权限实现代码

    1.Android屏幕常亮/点亮 复制代码 代码如下: //保持屏幕常亮 PowerManager pm = (PowerManager) getSystemService(Context.POWER_SERVICE); mWakeLock = pm.newWakeLock(PowerManager.FULL_WAKE_LOCK | PowerManager.ACQUIRE_CAUSES_WAKEUP, LOCK_TAG); mWakeLock.acquire(); 复制代码 代码如下: //释

  • Android权限控制之自定义权限

    天哪,这篇文章终于说道如何自定义权限了,左盼右盼,其实这个自定义权限相当easy.为了方便叙述,我这边会用到两个app作为例子示范. Permission App: used to define a new permission 这个作为定义权限的App,我称之为Permission App. Client App: used to access the specified activity of Permission App 这个作为访问上述自定义权限的App,我称之为Client App 先

  • 详解Android权限管理之Android 6.0运行时权限及解决办法

    前言: 今天还是围绕着最近面试的一个热门话题Android 6.0权限适配来总结学习,其实Android 6.0权限适配我们公司是在今年5月份才开始做,算是比较晚的吧,不过现在Android 6.0以上设备越来越多了,所以Android 6.0 权限适配是必不可少的工作,这里主要介绍一下我们公司是如何做Android 6.0权限适配的. Android 6.0以下非运行时权限: 根据上面博客我们很清楚的知道,Android的权限其实就是为了程序之间更加的安全的访问,所以权限有等级之分,比如:No

  • Android权限操作之uses-permission详解

    本文实例讲述了Android权限操作之uses-permission.分享给大家供大家参考,具体如下: 我们在安装Android软件的时候,系统会提示该软件所需要的权限,相对于其他系统,android的权限非常多.我们在开发软件的时候,也需要声明相应的权限,比如希望软件能发短信,需要声明软件调用短信的权限,否则软件运行的时候就会报错. Android的权限在AndroidManifest.xml文件里配置.AndroidManifest文件中有四个标签与permission有关,它们分别是 <p

  • Android中Root权限获取的简单代码

    我们知道Android手机操作系统采用的是Linux内核,Linux中最高的系统权限就是Root,这就类似与Windows中的Administrator系统管理员权限,也就是操作系统的最高权限.由于Root的权限过高,因此手机产商一般都不允许用户直接拥用Root权限,以防止用户修改系统内置的业务跟程序.但是对于用户来说,当然希望能拥有Root权限以将手机修改成自己的一种特色,因为有Root权限则可以任意修改手机的所有文件跟程序,让手机更加个性化. 复制代码 代码如下: Process proce

  • Android uses-permission权限列表中文注释版

    android同时也限定了系统资源的使用,像网络设备,SD卡,录音设备等.如果你的应用希望去使用任何系统资源,我们必须去申请Android的权限.这就是<uses-permission>元素的作用. 一个权限通常有以下格式,用一个名字为name 的字符串去指导我们希望使用的权限. 复制代码 代码如下: <uses-permission android:name="string"/> 例如:想要获得networking APIs的使用权限,我们指定如下的元素作为

  • android开发权限询问的示例代码

    现在基于信息安全问题,特别是版本是23以上权限越严格. 特别是拍照,读,写权限 一般权限允许过,下次就不用询问了的,所以很多应用都喜欢在首页或者启动页直接询问,不允许的就用不了1.下面给出封装好的类,至于什么时候调看项目需要 public class EasyPermissions { private static final String TAG = "EasyPermissions"; public interface PermissionCallbacks extends Act

  • Springboot+Vue+shiro实现前后端分离、权限控制的示例代码

    本文总结自实习中对项目的重构.原先项目采用Springboot+freemarker模版,开发过程中觉得前端逻辑写的实在恶心,后端Controller层还必须返回Freemarker模版的ModelAndView,逐渐有了前后端分离的想法,由于之前,没有接触过,主要参考的还是网上的一些博客教程等,初步完成了前后端分离,在此记录以备查阅. 一.前后端分离思想 前端从后端剥离,形成一个前端工程,前端只利用Json来和后端进行交互,后端不返回页面,只返回Json数据.前后端之间完全通过public A

  • Springboot+Spring Security实现前后端分离登录认证及权限控制的示例代码

    目录 前言 本文主要的功能 一.准备工作 1.统一错误码枚举 2.统一json返回体 3.返回体构造工具 4.pom 5.配置文件 二.数据库表设计 初始化表数据语句 三.Spring Security核心配置:WebSecurityConfig 四.用户登录认证逻辑:UserDetailsService 1.创建自定义UserDetailsService 2.准备service和dao层方法 五.用户密码加密 六.屏蔽Spring Security默认重定向登录页面以实现前后端分离功能 1.实

  • Spring Security实现统一登录与权限控制的示例代码

    目录 项目介绍 统一认证中心 配置授权服务器 配置WebSecurity 登录 菜单 鉴权 资源访问的一些配置 有用的文档 项目介绍 最开始是一个单体应用,所有功能模块都写在一个项目里,后来觉得项目越来越大,于是决定把一些功能拆分出去,形成一个一个独立的微服务,于是就有个问题了,登录.退出.权限控制这些东西怎么办呢?总不能每个服务都复制一套吧,最好的方式是将认证与鉴权也单独抽离出来作为公共的服务,业务系统只专心做业务接口开发即可,完全不用理会权限这些与之不相关的东西了.于是,便有了下面的架构图:

  • Android开发仿IOS滑动开关实现代码

    Android开发仿IOS滑动开关实现代码 Android与iOS相比,ios好多控件都是自带的,而android需要使用自定义来实现.今天说的是ios的滑动开关,我层看到好多博客都是通过自定义ToggleButton实现的.这里我通过自定义view来实现他的效果. 首先在onsizechange里把2个半圆和一个矩形绘制出来. width = w; height = h; left = top = 0; right = width; bottom = height * 0.8f; cx = (

  • Sublime开发python程序的示例代码

    本文介绍了Sublime开发python程序的示例代码,分享给大家,具体如下: 下载.安装Python程序 https://www.python.org/downloads/ 下载.安装 sublime http://www.sublimetext.com/ 关联python Preferences->Browers Packages ->Python ->Python.sublime-build 修改Python.sublime-build文件,增加python安装路径 { "

  • SpringBoot中整合Shiro实现权限管理的示例代码

    之前在 SSM 项目中使用过 shiro,发现 shiro 的权限管理做的真不错,但是在 SSM 项目中的配置太繁杂了,于是这次在 SpringBoot 中使用了 shiro,下面一起看看吧 一.简介 Apache Shiro是一个强大且易用的Java安全框架,执行身份验证.授权.密码和会话管理.使用Shiro的易于理解的API,您可以快速.轻松地获得任何应用程序,从最小的移动应用程序到最大的网络和企业应用程序. 三个核心组件: 1.Subject 即"当前操作用户".但是,在 Shi

  • vue实现菜单权限控制的示例代码

    大家在做后台管理系统时一般都会涉及到菜单的权限控制问题.当然解决问题的方法无非两种--前端控制和后端控制.我们公司这边的产品迭代速度较快,所以我们是从前端控制路由迭代到后端控制路由.下面我会分别介绍这两种方法的优缺点以及如何实现(不熟悉vue-router API的同学可以先去官网看一波API哈). 我先简单说下项目的需求:如下图所示,有一级菜单和二级菜单,然后不同的人登录进去会展示不同的菜单. 前端控制路由的思路:将所有的路由映射表都拿到前端来维护,就是我的router.js里面将所有的菜单p

  • Android实现微信登录的示例代码

    目录 一.布局界面 二.MainActivity.java 微信登录的实现与qq登录类似.不过微信登录比较麻烦,需要拿到开发者资质认证,花300块钱,然后应用的话还得有官网之类的,就是比较繁琐的前期准备工作,如果在公司里,这些应该都不是事,会有相关人提前准备好.在这里我们已经拿到了开发者认证,并且申请到了微信登录的授权. 现在直接介绍mob来实现微信登录的代码,并获取微信的相关数据,比较简单. 一.布局界面 布局界面只需要一个button来触发授权就可以 <Button android:id=&qu

  • Android绘制平移动画的示例代码

    目录 1.具体操作步骤 2.具体实施 创建ImageView 创建ObjectAnimator对象 3.具体实例 activity_main.xml MainActivity.java 1.具体操作步骤 创建ImageView对象 创建ObjectAnimator对象 通过ofFloat方法实现平移 2.具体实施 创建ImageView <ImageView android:id="@+id/car" android:layout_width="wrap_content

随机推荐