欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Android動態(tài)權(quán)限申請實現(xiàn)步驟分解

 更新時間:2023年04月03日 08:52:47   作者:別偷我的豬_09  
對于一些危險權(quán)限在AndroidManifest清單文件中申請之后,還需要得到用戶的許可并打開,才算是真正的開啟了這個權(quán)限。所以可以使用動態(tài)申請權(quán)限,對于某個功能,如果需要開啟某個權(quán)限,在用戶使用它之前,彈窗提示用戶是否要開啟這個權(quán)限

Google 在 Android 6.0 開始引入了權(quán)限申請機(jī)制,將所有權(quán)限分成了正常權(quán)限和危險權(quán)限。App 每次在使用危險權(quán)限時需要動態(tài)的申請并得到用戶的授權(quán)才能使用。

權(quán)限分類

系統(tǒng)權(quán)限分為兩類:正常權(quán)限和危險權(quán)限。

正常權(quán)限:不會直接給用戶隱私帶來危險。如果你在其清單中列出了正常權(quán)限,系統(tǒng)將自動授予該權(quán)限。

危險權(quán)限:授予應(yīng)用訪問用戶機(jī)密數(shù)據(jù)的權(quán)限。如果你在清單文件中列出了危險權(quán)限,則用戶必須明確批準(zhǔn)你的應(yīng)用使用這些權(quán)限。那么危險權(quán)限有那些?日歷(CALENDAR)、相機(jī)(CAMERA)、通訊錄(CONTACTS)、位置(LOCATION)、撥號(PHONE)、短信(SMS)和存儲(STORAGE)等。

<!-- 權(quán)限組:CALENDAR == 日歷讀取的權(quán)限申請 -->
<uses-permission android:name="android.permission.READ_CALENDAR" />
<uses-permission android:name="android.permission.WRITE_CALENDAR" />
<!-- 權(quán)限組:CAMERA == 相機(jī)打開的權(quán)限申請 -->
<uses-permission android:name="android.permission.CAMERA" />
<!-- 權(quán)限組:CONTACTS == 聯(lián)系人通訊錄信息獲取/寫入的權(quán)限申請 -->
<uses-permission android:name="android.permission.READ_CONTACTS" />
<uses-permission android:name="android.permission.WRITE_CONTACTS" />
<!-- 權(quán)限組:LOCATION == 位置相關(guān)的權(quán)限申請 -->
<uses-permission android:name="android.permission.ACCESS_FINE_LOCATION" />
<uses-permission android:name="android.permission.ACCESS_COARSE_LOCATION" />
<!-- 權(quán)限組:PHONE == 撥號相關(guān)的權(quán)限申請 -->
<uses-permission android:name="android.permission.CALL_PHONE" />
<uses-permission android:name="android.permission.READ_PHONE_STATE" />
<!-- 權(quán)限組:SMS == 短信相關(guān)的權(quán)限申請 -->
<uses-permission android:name="android.permission.SEND_SMS" />
<uses-permission android:name="android.permission.READ_SMS" />
<!-- 權(quán)限組:STORAGE == 讀取存儲相關(guān)的權(quán)限申請 -->
<uses-permission android:name="android.permission.READ_EXTERNAL_STORAGE" />
<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" />

申請以上權(quán)限時,除了要在清單文件中添加權(quán)限,還需要通過代碼動態(tài)申請。

動態(tài)權(quán)限核心函數(shù)

1. 檢測權(quán)限

checkSelfPermission(@NonNull String permission)

2. 申請權(quán)限

requestPermissions(@NonNull String[] permissions, int requestCode)

3. 處理結(jié)果回調(diào)

onRequestPermissionsResult(int requestCode, @NonNull String[] permissions, @NonNull int[] grantResults)

4. 是否需要顯示 UI 界面提示用戶為什么需要這個權(quán)限

shouldShowRequestPermissionRationale(@NonNull String permission)

簡易實現(xiàn)案例

步驟1:在 AndroidManifest.xml 添加要申請的權(quán)限。這里以存儲權(quán)限為例

<!-- STORAGE == 讀取存儲相關(guān)權(quán)限-->
<uses-permission android:name="android.permission.READ_EXTERNAL_STORAGE"/>

步驟2:封裝一個 requestPermission 方法來動態(tài)檢測和申請權(quán)限

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

requestPermission() 函數(shù)里會先檢測存儲權(quán)限,如果沒開啟則動態(tài)申請存儲權(quán)限。

private void requestPermission() {
        // checkSelfPermission() 檢測權(quán)限
        if (ContextCompat.checkSelfPermission(this, Manifest.permission.READ_EXTERNAL_STORAGE)
        != PackageManager.PERMISSION_GRANTED) {
            //TODO 申請存儲權(quán)限
            ActivityCompat.requestPermissions(this, new String[]{Manifest.permission.READ_EXTERNAL_STORAGE},
                    PERMISSION_REQUEST_CODE);
        }
    }

注意:這個 demo 里只申請了一個權(quán)限,當(dāng)我們需要申請多個權(quán)限時,可以往requestPermissions 里的第二個參數(shù)添加其它需要的權(quán)限,因為它本就是一個 String 數(shù)組,且也要在 AndroidManifest里添加。

new String[]{Manifest.permission.READ_EXTERNAL_STORAGE
                    ,Manifest.permission.CAMERA}

步驟3:處理用戶選擇的結(jié)果(“允許” / “拒絕”),重寫 onRequestPermissionsResult()方法。

//TODO 處理權(quán)限結(jié)果回調(diào)
    @Override
    public void onRequestPermissionsResult(int requestCode, @NonNull String[] permissions, @NonNull int[] grantResults) {
        super.onRequestPermissionsResult(requestCode, permissions, grantResults);
        if (requestCode == PERMISSION_REQUEST_CODE) {
            //用戶點擊了“確定” == grantResults[0] == PackageManager.PERMISSION_GRANTED)
            if (grantResults.length > 0 && grantResults[0] == PackageManager.PERMISSION_GRANTED) {
                Log.i("TAG", "onRequestPermissionsResult granted");
            } else {
                Log.i("TAG", "onRequestPermissionsResult denied");
                // TODO 用戶拒絕權(quán)限申請,則彈出警示框
                showWaringDialog();
            }
        }
    }

步驟4:當(dāng)用戶拒絕權(quán)限,則彈出警示框,并在用戶點擊“確定”后直接退出頁面。因為沒有存儲權(quán)限肯定不能使用該應(yīng)用的。

/**
     * 用戶拒絕權(quán)限的警示
     */
    private void showWaringDialog() {
        new AlertDialog.Builder(this)
                .setTitle("警告!")
                .setMessage("請前往設(shè)置->應(yīng)用->權(quán)限管理->打開存儲權(quán)限,否則無法正常使用!")
                .setPositiveButton("確定", new DialogInterface.OnClickListener() {
                    @Override
                    public void onClick(DialogInterface dialog, int which) {
                        //TODO 一般情況下如果用戶不授權(quán)的話,功能時無法運(yùn)行的,則直接退出
                        finish();
                    }
                }).show();
    }

完整代碼

MainActivity.java

package com.example.dynamicauthority;
import androidx.annotation.NonNull;
import androidx.appcompat.app.AppCompatActivity;
import androidx.core.app.ActivityCompat;
import androidx.core.content.ContextCompat;
import android.Manifest;
import android.app.AlertDialog;
import android.content.DialogInterface;
import android.content.pm.PackageManager;
import android.os.Bundle;
import android.util.Log;
public class MainActivity extends AppCompatActivity {
    private static final int PERMISSION_REQUEST_CODE = 999;
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        requestPermission();
    }
    private void requestPermission() {
        // checkSelfPermission() 檢測權(quán)限
        if (ContextCompat.checkSelfPermission(this, Manifest.permission.READ_EXTERNAL_STORAGE)
        != PackageManager.PERMISSION_GRANTED) {
            //TODO 申請存儲權(quán)限
            ActivityCompat.requestPermissions(this, new String[]{Manifest.permission.READ_EXTERNAL_STORAGE},
                    PERMISSION_REQUEST_CODE);
        }
    }
    //TODO 處理權(quán)限結(jié)果回調(diào)
    @Override
    public void onRequestPermissionsResult(int requestCode, @NonNull String[] permissions, @NonNull int[] grantResults) {
        super.onRequestPermissionsResult(requestCode, permissions, grantResults);
        if (requestCode == PERMISSION_REQUEST_CODE) {
            //用戶點擊了“確定” == grantResults[0] == PackageManager.PERMISSION_GRANTED)
            if (grantResults.length > 0 && grantResults[0] == PackageManager.PERMISSION_GRANTED) {
                Log.i("TAG", "onRequestPermissionsResult granted");
            } else {
                Log.i("TAG", "onRequestPermissionsResult denied");
                // TODO 用戶拒絕權(quán)限申請,則彈出警示框
                showWaringDialog();
            }
        }
    }
    /**
     * 用戶拒絕權(quán)限的警示
     */
    private void showWaringDialog() {
        new AlertDialog.Builder(this)
                .setTitle("警告!")
                .setMessage("請前往設(shè)置->應(yīng)用->權(quán)限管理->打開存儲權(quán)限,否則無法正常使用!")
                .setPositiveButton("確定", new DialogInterface.OnClickListener() {
                    @Override
                    public void onClick(DialogInterface dialog, int which) {
                        //TODO 一般情況下如果用戶不授權(quán)的話,功能時無法運(yùn)行的,則直接退出
                        finish();
                    }
                }).show();
    }
}

到此這篇關(guān)于Android動態(tài)權(quán)限申請實現(xiàn)步驟分解的文章就介紹到這了,更多相關(guān)Android動態(tài)權(quán)限申請內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

最新評論