Android 6.0以降のダイナミック権限

11300 ワード

原文の住所:http://blog.magicer.xyz/2017/01/android-api-23-permission/
前言
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; } }