Android之運行時權限

1.有關權限

  • Normal Permission

這類權限一般不涉及用戶隱私,是無須用戶進行授權的,系統自動幫我們授權,只需要在AndroidMainfest.xml中聲明即可,如訪問網絡,安裝時就授權,無須每次使用時都檢查權限

  • Dangerous Permission

一般會涉及用戶隱私,需要用戶進行授權,比如讀取sdcard、訪問通信錄等,在程序運行時要求手動點擊申請權限,也就是運行是時權限,如下:

在這裏插入圖片描述

以上同一組的任何一個權限被授權,其他權限也自動被授權

2.Dangerous Permission實例

對於Dangerous Permission,如:撥打電話時權限Action_CALL,使用時先調用checkSelfPermission檢查權限,沒有權限則申請權限requestPermissions,並回調onRequestPermissionsResult方法

2.1 申請權限

申請權限分以下兩個步驟:

  • AndroidManifest.xml中申請權限,如下:
<uses-permission android:name="android.permission.CALL_PHONE" />
  • 使用相應的API方法動態申請

採用如下流程:checkSelfPermission(檢查是否已被授予)—>requestPermissions(申請權限)—>onRequestPermissionsResult(自動回調),代碼如下:

public class MainActivity extends AppCompatActivity {

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        Button bt = findViewById(R.id.make_call);
        bt.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {
                if (ContextCompat.checkSelfPermission(MainActivity.this, Manifest.permission.CALL_PHONE) != PackageManager.PERMISSION_GRANTED) {
                    ActivityCompat.requestPermissions(MainActivity.this, new String[]{Manifest.permission.CALL_PHONE}, 1);
                } else {
                    call();
                }
            }
        });
    }

    private void call() {
        try {
            Intent intent = new Intent(Intent.ACTION_CALL);
            intent.setData(Uri.parse("tel:10086"));
            if (checkSelfPermission(Manifest.permission.CALL_PHONE) != PackageManager.PERMISSION_GRANTED) {
               return;
            }
            startActivity(intent);
        } catch (Exception e) {
            e.printStackTrace();
        }
    }

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

        switch (requestCode) {
            case 1:
                if (grantResults.length > 0 && grantResults[0] == PackageManager.PERMISSION_GRANTED) {
                    call();
                } else {
                    Toast.makeText(this, "Denied Permission", Toast.LENGTH_SHORT).show();

                }
                break;
            default:
        }

    }
}

PS:如果在運行時授權了權限,但是想手動關閉,可以在設置----應用—找到對應的應用—權限,可以關閉對應的權限

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章