您的位置:首页 > 移动开发 > Android开发

关于Android6.0之后的权限问题

2016-11-10 18:01 204 查看
https://github.com/mylhyl/AndroidAcp

AndroidAcp

使用:

加入

compile 'com.mylhyl:acp:1.1.7'

PermisionUtils.newInstance().checkReadStoragePermission(getWindow().getDecorView().findViewById(android.R.id.content), new PermisionUtils.OnPermissionGrantedLintener() {
@Override
public void permissionGranted() {
//打开权限的操作

}
});


public class PermisionUtils {
private static PermisionUtils utils;

private PermisionUtils() {
}

public static PermisionUtils newInstance() {
if (utils == null) {
synchronized (PermisionUtils.class) {
if (utils == null) {
utils = new PermisionUtils();
}
}
}
return utils;
}
/**
* camera权限检查
*
* @param view
* @param lintener
*/
public void checkCameraPermission(final View view, final OnPermissionGrantedLintener lintener) {
Acp.getInstance(view.getContext()).request(new AcpOptions.Builder().setPermissions(Manifest.permission.CAMERA).build(), new AcpListener() {
@Override
public void onGranted() {
if (lintener != null) {
lintener.permissionGranted();
}
}

@Override
public void onDenied(List<String> permissions) {
ToastUtils.showSnackBar(view, "请打开摄像权限后使用");
}
});
}

}


AndroidAcp

Acp 为 Android check permission 缩写,此库简化Android 6.0 系统复杂的权限操作而编写。

特点

支持批量权限申请,不需要重写 onRequestPermissionsResult 方法,Activity 与 Fragment 中用法一致,一句话搞定。

处理权限拒绝,或勾选不再询问,导致不能正常使用功能的提示框,支持跳转设置权限界面开启权限,所有提示框文字可自定义。

效果图





使用Gradle构建时添加一下依赖即可:

compile 'com.mylhyl:acp:1.1.7'


使用说明

Acp.getInstance(this).request(new AcpOptions.Builder()
.setPermissions(Manifest.permission.WRITE_EXTERNAL_STORAGE
, Manifest.permission.READ_PHONE_STATE
, Manifest.permission.SEND_SMS)
/*以下为自定义提示语、按钮文字
.setDeniedMessage()
.setDeniedCloseBtn()
.setDeniedSettingBtn()
.setRationalMessage()
.setRationalBtn()*/
.build(),
new AcpListener() {
@Override
public void onGranted() {
writeSD();
getIMEI();
}

@Override
public void onDenied(List<String> permissions) {
makeText(permissions.toString() + "权限拒绝");
}
});


友情提示

android studio
环境 请求
Manifest.permission.CALL_PHONE
权限时,Intent不能使用带参的构造函数(Intent.ACTION_CALL),否则会编译通不过的。 由于手机厂商深度定制系统的原因,很多预料不到滴,奇怪滴问题一大堆,如
checkSelfPermission
永远都是
PERMISSION_DENIED
PERMISSION_GRANTED
,都是坑爹的无解,小弟不才帮不到大家,望大神指点一二三!

下载APK体验

QQ交流群:435173211

版本日志


1.1.7 修复内存泄露

1.1.6 Acp单例增加双重锁

1.1.5 兼容小米跳转权限设置

1.1.2 增加
M
版本检测

1.0.2 修复申请的权限不在
AndroidManifest.xml
配置文件时,中仍然显示
RationalMessage
对话框的问题

1.0.1 修改 minSdkVersion 14



地址
https://github.com/hongyangAndroid/MPermissions
project's build.gradle

buildscript {
dependencies {
classpath 'com.neenbedankt.gradle.plugins:android-apt:1.4'
}
}

module's buid.gradle

apply plugin: 'com.neenbedankt.android-apt'

dependencies {
apt 'com.zhy:mpermission-compiler:1.0.0'
compile 'com.zhy:mpermission-api:1.0.0'
}


dependencise:一个就行了:compile 'com.zhy:mpermission-api:1.0.0'

使用方法

final int REQUECT_CODE_READ_SMS = 100;

MPermissions.requestPermissions(AnayseSmsUploadActivity.this, REQUECT_CODE_READ_SMS, Manifest.permission.READ_SMS);


@Override
public void onRequestPermissionsResult(int requestCode, String[] permissions, int[] grantResults) {
MPermissions.onRequestPermissionsResult(this, requestCode, permissions, grantResults);
super.onRequestPermissionsResult(requestCode, permissions, grantResults);
}

//请求成功
@PermissionGrant(REQUECT_CODE_READ_SMS)
public void requestSdcardSuccess() {

}

//请求失败

@PermissionDenied(REQUECT_CODE_READ_SMS)
public void requestSdcardFailed() {
finash();
}

MPermissions

基于Annotation Processor的简单易用的处理Android M运行时权限的库。

部分代码来自PermissionGen, 主要是将其基于运行时注解的实现修改为Annotation Processor的方式,即编译时注解。

引入

project's build.gradle

buildscript {
dependencies {
classpath 'com.neenbedankt.gradle.plugins:android-apt:1.4'
}
}

module's buid.gradle

apply plugin: 'com.neenbedankt.android-apt'

dependencies {
apt 'com.zhy:mpermission-compiler:1.0.0'
compile 'com.zhy:mpermission-api:1.0.0'
}

使用

申请权限

MPermissions.requestPermissions(MainActivity.this, REQUECT_CODE_SDCARD, Manifest.permission.WRITE_EXTERNAL_STORAGE);


处理权限回调

@Override
public void onRequestPermissionsResult(int requestCode, String[] permissions, int[] grantResults)
{
MPermissions.onRequestPermissionsResult(this, requestCode, permissions, grantResults);
super.onRequestPermissionsResult(requestCode, permissions, grantResults);
}


是否需要弹出解释

if (!MPermissions.shouldShowRequestPermissionRationale(MainActivity.this, Manifest.permission.WRITE_EXTERNAL_STORAGE, REQUECT_CODE_SDCARD))
{
MPermissions.requestPermissions(MainActivity.this, REQUECT_CODE_SDCARD, Manifest.permission.WRITE_EXTERNAL_STORAGE);
}

如果需要解释,会自动执行使用
@ShowRequestPermissionRationale
注解的方法。

授权成功以及失败调用的分支方法通过注解
@PermissionGrant
@PermissionDenied
进行标识,详细参考下面的例子或者sample。

例子

in Activity:

public class MainActivity extends AppCompatActivity
{

private Button mBtnSdcard;
private static final int REQUECT_CODE_SDCARD = 2;

@Override
protected void onCreate(Bundle savedInstanceState)
{
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);

mBtnSdcard = (Button) findViewById(R.id.id_btn_sdcard);
mBtnSdcard.setOnClickListener(new View.OnClickListener()
{
@Override
public void onClick(View v)
{
MPermissions.requestPermissions(MainActivity.this, REQUECT_CODE_SDCARD, Manifest.permission.WRITE_EXTERNAL_STORAGE);
}
});
}

@Override public void onRequestPermissionsResult(int requestCode, String[] permissions, int[] grantResults) { MPermissions.onRequestPermissionsResult(this, requestCode, permissions, grantResults); super.onRequestPermissionsResult(requestCode, permissions, grantResults); }

@PermissionGrant(REQUECT_CODE_SDCARD)
public void requestSdcardSuccess()
{
Toast.makeText(this, "GRANT ACCESS SDCARD!", Toast.LENGTH_SHORT).show();
}

@PermissionDenied(REQUECT_CODE_SDCARD)
public void requestSdcardFailed()
{
Toast.makeText(this, "DENY ACCESS SDCARD!", Toast.LENGTH_SHORT).show();
}
}


in Fragment:

public class TestFragment extends Fragment
{
@Nullable
@Override
public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState)
{
return inflater.inflate(R.layout.fragment_test, container, false);
}

@Override
public void onViewCreated(View view, @Nullable Bundle savedInstanceState)
{
view.findViewById(R.id.id_btn_contact).setOnClickListener(new View.OnClickListener()
{
@Override
public void onClick(View v)
{
MPermissions.requestPermissions(TestFragment.this, 4, Manifest.permission.WRITE_CONTACTS);
}
});

}

@PermissionGrant(4)
public void requestContactSuccess()
{
Toast.makeText(getActivity(), "GRANT ACCESS CONTACTS!", Toast.LENGTH_SHORT).show();
}

@PermissionDenied(4)
public void requestContactFailed()
{
Toast.makeText(getActivity(), "DENY ACCESS CONTACTS!", Toast.LENGTH_SHORT).show();
}

@Override public void onRequestPermissionsResult(int requestCode, String[] permissions, int[] grantResults) { MPermissions.onRequestPermissionsResult(this, requestCode, permissions, grantResults); super.onRequestPermissionsResult(requestCode, permissions, grantResults); }
}


混淆

-dontwarn com.zhy.m.**
-keep class com.zhy.m.** {*;}
-keep interface com.zhy.m.** { *; }
-keep class **$$PermissionProxy { *; }
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: