生活随笔
收集整理的這篇文章主要介紹了
Android权限之动态权限
小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.
安卓系統(tǒng)的權(quán)限管理機(jī)制從API 23 (也就是Android 6.0 又叫做 Android M,)之后發(fā)生了比較大的改變,在一些比較危險的權(quán)限上要求必須申請動態(tài)權(quán)限,即使你在AndroidMainfest.xml文件中申請也沒有任何用,或者你可以將編譯的目標(biāo)版本設(shè)定這API 22,這樣就可以了。但這并不是長久之計,不是嗎?所以因此在這里學(xué)習(xí)一下。
動態(tài)權(quán)限需求原因 Android?6.0之前,權(quán)限在應(yīng)用安裝過程中只詢問一次,以列表的形式展現(xiàn)給用戶,然而大多數(shù)用戶并不會注意到這些,直接就下一步了,應(yīng)用安裝成功后就會被賦予清單文件中的所有權(quán)限,應(yīng)用就可以在用戶不知情的情況下進(jìn)行非法操作(比如偷偷的上傳用戶數(shù)據(jù))。 需要動態(tài)申請的權(quán)限如下: READ_CALENDAR , WRITE_CALENDAR 讀寫日歷權(quán)限 CAMERA 調(diào)用相機(jī)權(quán)限 READ_CONTACTS , WRITE_CONTACTS , GET_ACCOUNTS 通訊錄權(quán)限 ACCESS_FINE_LOCATION, ACCESS_COARSE_LOCATION 定位權(quán)限 RECORD_AUDIO 錄音權(quán)限 READ_PHONE_STATE ,CALL_PHONE READ_CALL_LOG, WRITE_CALL_LOG ADD_VOICEMAIL//手機(jī)狀態(tài)相關(guān) BODY_SENSORS 傳感器權(quán)限 SMS SEND_SMS ,RECEIVE_SMS ,READ_SMS, RECEIVE_WAP_PUSH, RECEIVE_MMS SMS消息權(quán)限 10.READ_EXTERNAL_STORAGE ,WRITE_EXTERNAL_STORAGE 外部存儲權(quán)限 動態(tài)權(quán)限申請步驟 AndroidMainfest.xml文件配置 沒有具體分析是什么原因,可能是為了兼容低版本吧,有興趣的自行Google一下 判斷Android系統(tǒng)版本 在官方的文檔中,可以看到低于API23 是不需要使用動態(tài)權(quán)限申請的,我們需要判斷一下,代碼如下: 如果是Android 6.0以上的系統(tǒng),需要進(jìn)行判斷,我們大致看一下 if (Build.VERSION.SDK_INT>=23) { //此處做動態(tài)權(quán)限申請 }else { //低于23 不需要特殊處理 }}
檢查權(quán)限 如果版本高于23 ,則需要進(jìn)行特殊處理,我們這里檢查一下有沒有權(quán)限 使用ContextCompat.CheckSlefPermission ,我們看看API解釋,從源代碼中找到這方法,我們來分析一下 /** * Determine whether <em>you</em> have been granted a particular permission.
* * @param permission The name of the permission being checked.
* * @return {@linkandroid.content.pm.PackageManager#PERMISSION_GRANTED} if you have the
* permission, or {@link android.content.pm.PackageManager#PERMISSION_DENIED} if not.
* * @see android.content.pm.PackageManager#checkPermission(String, String) */
public static int checkSelfPermission(@NonNull Context context, @NonNull String permission)
{ if (permission == null){ throw new IllegalArgumentException("permission is null"); } return context.checkPermission(permission, android.os.Process.myPid(), Process.myUid());}
參數(shù):一個上下文Context和一個權(quán)限的名稱。 返回:PERMISSION_GRANTED 存在權(quán)限以及PERMISSION_DENIED 不存在權(quán)限 同時又調(diào)用了context.checkPermission方法,我們來看一下參數(shù),拿到了一個String類型的數(shù)據(jù),這個是權(quán)限的名稱嗎,以及當(dāng)前進(jìn)程的PID和UID,有興趣額的可以繼續(xù)深究 申請權(quán)限 如果發(fā)現(xiàn)CheckSelfPermission返回值是 PERMISSION_DENIED,則需要進(jìn)行權(quán)限申請,我們這里看一下怎么申請的 使用ContextCompat.CheckSlefPermission ,我們看看API解釋,從源代碼中找到這方法,我們來分析一下 ActivityCompat.requestPermissions(thisActivity,?new String[]{Manifest.permission.READ_CONTACTS},?REQUEST_CODE);
參數(shù)說明: 當(dāng)前上下文。一個權(quán)限數(shù)組,還有一個唯一的請求碼,注意這個請求碼要大于0 ,低于65535,因為程序要求請求碼只能是16位的數(shù)據(jù),被坑了一次 上下文就不說了,權(quán)限數(shù)組,說明是可以一次申請多個權(quán)限的,由于這個權(quán)限請求是異步操作的,所以說,用戶判斷權(quán)限后需要回調(diào)函數(shù),那么就用到這個請求碼了,好了,我們先來看看整體的邏輯代碼 if (Build.VERSION.SDK_INT>=23) { int request=ContextCompat.checkSelfPermission(this, Manifest.permission.CAMERA); if (request!= PackageManager.PERMISSION_GRANTED)//缺少權(quán)限,進(jìn)行權(quán)限申請 { ActivityCompat.requestPermissions(this,new String[]{Manifest.permission.CAMERA},825638); return;// }else { //權(quán)限同意}}else{ //低于23 不需要特殊處理,去掉用拍照的方法 }
回調(diào)函數(shù)的處理 由于程序是異步操作,在用戶完成了操作后,需要調(diào)用回調(diào)函數(shù),而此回調(diào)函數(shù)則是一個Activity的放,因此重寫Activity的方法
//參數(shù) requestCode是我們在申請權(quán)限的時候使用的唯一的申請碼
//String[] permission則是權(quán)限列表,一般用不到//int[] grantResults 是用戶的操作響應(yīng),包含這權(quán)限是夠請求成功//由于在權(quán)限申請的時候,我們就申請了一個權(quán)限,所以此處的數(shù)組的長度都是1@Overridepublic void onRequestPermissionsResult(int requestCode, @NonNull String[] permissions, @NonNull int[]
grantResults) { super.onRequestPermissionsResult(requestCode, permissions, grantResults); if (requestCode==123) { //當(dāng)然權(quán)限多了,建議使用Switch,不必糾結(jié)于此 if (grantResults[0]==PackageManager.PERMISSION_GRANTED) {Toast.makeText(this, "權(quán)限申請成功", Toast.LENGTH_SHORT).show(); }else if (grantResults[0]== PackageManager.PERMISSION_DENIED) { Toast.makeText(this, "權(quán)限申請失敗,用戶拒絕權(quán)限", Toast.LENGTH_SHORT).show(); } }}
代碼套餐 代碼比較簡單,邊學(xué)邊寫的,收獲很大,以后要多寫B(tài)LOG了,比自己看一遍理解更深,記得更牢靠 package cn.wuhu.authority;
import android.Manifest;
import android.content.pm.PackageManager;import android.os.Build;
import android.support.annotation.NonNull;
import android.support.v4.app.ActivityCompat;
import android.support.v4.content.ContextCompat;
import android.support.v4.content.PermissionChecker;
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;import android.view.View;
import android.widget.Toast;
public class MainActivity extends AppCompatActivity {
@Overrideprotected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);setContentView(R.layout.activity_main); findViewById(R.id.button).setOnClickListener(new View.OnClickListener() { @Overridepublic void onClick(View view) {onTakePhoto();}});}public void onTakePhoto() { if (Build.VERSION.SDK_INT>=23) {int request=ContextCompat.checkSelfPermission(this, Manifest.permission.CAMERA);if (request!= PackageManager.PERMISSION_GRANTED)//缺少權(quán)限,進(jìn)行權(quán)限申請{ ActivityCompat.requestPermissions(this,new String[]{Manifest.permission.CAMERA},123);return;//}else{//權(quán)限同意,不需要處理,去掉用拍照的方法 Toast.makeText(this,"權(quán)限同意",Toast.LENGTH_SHORT).show();}}else{//低于23 不需要特殊處理,去掉用拍照的方法}}//參數(shù) requestCode是我們在申請權(quán)限的時候使用的唯一的申請碼 //String[] permission則是權(quán)限列表,一般用不到//int[] grantResults 是用戶的操作響應(yīng),包含這權(quán)限是夠請求成功//由于在權(quán)限申請的時候,我們就申請了一個權(quán)限,所以此處的數(shù)組的長度都是1@Overridepublic void onRequestPermissionsResult(int requestCode, @NonNull String[] permissions, @NonNull int[] grantResults) { super.onRequestPermissionsResult(requestCode, permissions, grantResults); if (requestCode==123) { //當(dāng)然權(quán)限多了,建議使用Switch,不必糾結(jié)于此if (grantResults[0]==PackageManager.PERMISSION_GRANTED) {Toast.makeText(this, "權(quán)限申請成功",Toast.LENGTH_SHORT).show();}else if (grantResults[0]== PackageManager.PERMISSION_DENIED) { Toast.makeText(this, "權(quán)限申請失敗,用戶拒絕權(quán)限", Toast.LENGTH_SHORT).show();}} }
}
轉(zhuǎn)載于:https://www.cnblogs.com/zhoutao825638/p/10382024.html
總結(jié)
以上是生活随笔 為你收集整理的Android权限之动态权限 的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
如果覺得生活随笔 網(wǎng)站內(nèi)容還不錯,歡迎將生活随笔 推薦給好友。