Android 6.0以降のダイナミック権限
11300 ワード
原文の住所:http://blog.magicer.xyz/2017/01/android-api-23-permission/
前言
Android 6.0の前にAndroidアプリケーションを開発する場合、開発者はどのような権限を必要としますか?
パーミッション分類
公式の権限教程は危険な権限を使う必要がある時、私達はダイナミックな申請権限が必要です.
危険権限
一般的なパーミッション
通常の権限については、リストファイルに登録すればいいです.
動的登録権限
あなたのアプリケーションに危険な権限が必要であれば、その権限が必要な操作を行うたびに、自分がその権限を持っているかどうかを確認しなければなりません.ユーザは常にこの権限を自由に呼び出すことができますので、昨日カメラを使っても、自分が今日もこの権限を持っているとは言えません.
権限があるかどうかを確認するには、
以上は公式文書で検出権限について説明しました.先にデモさんに来てください.どのようなダイナミックな要求権限を見ても、公式文書の紹介を見ることができます.
前言
Android 6.0の前にAndroidアプリケーションを開発する場合、開発者はどのような権限を必要としますか?
AndroidManifest.xml
ファイルに表示される声明だけでいいです.以下のとおりです <uses-permission android:name="android.permission.INTERNET"/>
<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE"/>
<uses-permission android:name="android.permission.READ_EXTERNAL_STORAGE"/>
しかし、Android 6.0の後、Androidはアプリケーションの権限をさらに規範化した.危険権限と一般権限があります.危険権限が必要な場合は運行時に授権する必要があります.こうするのもいいです.いくつかのアプリケーションユーザーの選択がより多くなりました.パーミッション分類
公式の権限教程は危険な権限を使う必要がある時、私達はダイナミックな申請権限が必要です.
危険権限
一般的なパーミッション
通常の権限については、リストファイルに登録すればいいです.
動的登録権限
あなたのアプリケーションに危険な権限が必要であれば、その権限が必要な操作を行うたびに、自分がその権限を持っているかどうかを確認しなければなりません.ユーザは常にこの権限を自由に呼び出すことができますので、昨日カメラを使っても、自分が今日もこの権限を持っているとは言えません.
権限があるかどうかを確認するには、
ContextCompat.checkSelfPermission()
メソッドを呼び出してください.例えば、次のコードセグメントは、Activityがカレンダーに書き込む権限を持っているかどうかを確認する方法を示しています.// Assume thisActivity is the current activity
int permissionCheck = ContextCompat.checkSelfPermission(thisActivity,
Manifest.permission.WRITE_CALENDAR);
この権限が適用されると、方法はPackageManager.PERMISSION_GRANTED
に戻り、アプリケーションは動作を継続することができる.アプリケーションがこの権限を持っていない場合、方法はPERMISSION_DENIED
に戻り、アプリケーションはユーザに権限を明確に要求しなければならない.以上は公式文書で検出権限について説明しました.先にデモさんに来てください.どのようなダイナミックな要求権限を見ても、公式文書の紹介を見ることができます.
private static final int PERMISSION_REQUEST_CODE = 1; //
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
if (checkPermission(this, Manifest.permission.WRITE_EXTERNAL_STORAGE)) {
// 。
}else {
//
ActivityCompat.requestPermissions(this,
new String[]{Manifest.permission.WRITE_EXTERNAL_STORAGE},
PERMISSION_REQUEST_CODE);
}
}
/**
*
* @return
*/
private boolean checkPermission(Context context, String permission) {
return PackageManager.PERMISSION_GRANTED == ContextCompat.checkSelfPermission(context,permission);
}
@Override
public void onRequestPermissionsResult(int requestCode, @NonNull String[] permissions, @NonNull int[] grantResults) {
super.onRequestPermissionsResult(requestCode, permissions, grantResults);
switch (requestCode){
case PERMISSION_REQUEST_CODE:
if (grantResults.length >0 &&
grantResults[0] == PackageManager.PERMISSION_GRANTED){
//
Toast.makeText(this, " ", Toast.LENGTH_SHORT).show();
}else {
//
Toast.makeText(this, " ", Toast.LENGTH_SHORT).show();
}
break;
default:
break;
}
}
ユーザーが
ボタンをクリックした後、今度はまたこの権限が必要です.どうすればいいですか?shoudShow Request PermissionRationle関数は、ユーザが禁止をクリックした後にtrue
に戻ります.私たちはこの方法でtrueに戻る時にユーザに権限を開くように促すことができます.コードは上のと同じです.簡単に見てもいいです. private static final int PERMISSION_REQUEST_CODE = 1; //
private Button mButton;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
mButton = (Button) findViewById(R.id.activity_main_storage_btn);
mButton.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
storagePermission();
}
});
}
private void storagePermission() {
if (checkPermission(this, Manifest.permission.WRITE_EXTERNAL_STORAGE)) {
// 。
}else {
// //
// ActivityCompat.requestPermissions(this,
// new String[]{Manifest.permission.WRITE_EXTERNAL_STORAGE},
// PERMISSION_REQUEST_CODE);
if (ActivityCompat.shouldShowRequestPermissionRationale(this, Manifest.permission.WRITE_EXTERNAL_STORAGE)) {
Toast.makeText(this, " ", Toast.LENGTH_SHORT).show();
showRequestPermissionDialog(new String[]{Manifest.permission.WRITE_EXTERNAL_STORAGE},PERMISSION_REQUEST_CODE);
}else {
ActivityCompat.requestPermissions(this,
new String[]{Manifest.permission.WRITE_EXTERNAL_STORAGE},
PERMISSION_REQUEST_CODE);
}
}
}
private void showRequestPermissionDialog(final String[] permissions, final int requestCode) {
AlertDialog.Builder builder = new AlertDialog.Builder(this);
builder.setMessage(" SD
");
builder.setPositiveButton(" ", new DialogInterface.OnClickListener() {
@Override
public void onClick(DialogInterface dialog, int which) {
ActivityCompat.requestPermissions(MainActivity.this,permissions,requestCode);
}
});
builder.setNegativeButton(" ",null);
builder.setCancelable(true);
builder.show();
}
/**
*
* @return
*/
private boolean checkPermission(Context context, String permission) {
return PackageManager.PERMISSION_GRANTED == ContextCompat.checkSelfPermission(context,permission);
}
@Override
public void onRequestPermissionsResult(int requestCode, @NonNull String[] permissions, @NonNull int[] grantResults) {
super.onRequestPermissionsResult(requestCode, permissions, grantResults);
switch (requestCode){
case PERMISSION_REQUEST_CODE:
if (grantResults.length >0 &&
grantResults[0] == PackageManager.PERMISSION_GRANTED){
//
Toast.makeText(this, " ", Toast.LENGTH_SHORT).show();
}else {
//
Toast.makeText(this, " ", Toast.LENGTH_SHORT).show();
}
break;
default:
break;
}
}