安卓Android6.0權(quán)限動(dòng)態(tài)獲取操作示例
本文實(shí)例講述了安卓Android6.0權(quán)限動(dòng)態(tài)獲取操作。分享給大家供大家參考,具體如下:
眾所周知 , 安卓6.0現(xiàn)在運(yùn)用的越來(lái)越廣泛 , 因?yàn)橄鄬?duì)于之前的幾個(gè)版本 , 對(duì)于用戶權(quán)限這個(gè)概念確實(shí)不是很重視 , 而6.0 之后 , 為了提升用戶的操作安全性 , 運(yùn)行時(shí)權(quán)限誕生了, 就是在用戶運(yùn)行軟件的時(shí)候動(dòng)態(tài)獲取所需要的權(quán)限 , 下面跟大家分享一個(gè)我的代碼案例 :
import android.Manifest; import android.app.AlertDialog; import android.content.DialogInterface; import android.content.Intent; import android.content.pm.PackageManager; import android.net.Uri; import android.provider.Settings; import android.support.v4.app.ActivityCompat; import android.support.v4.content.ContextCompat; import android.support.v7.app.AppCompatActivity; import android.view.KeyEvent; import java.util.ArrayList; import java.util.List; /** * 繼承了Activity,實(shí)現(xiàn)Android6.0的運(yùn)行時(shí)權(quán)限檢測(cè) * 需要進(jìn)行運(yùn)行時(shí)權(quán)限檢測(cè)的Activity可以繼承這個(gè)類 * * @author xingtao sun * @創(chuàng)建時(shí)間:2016年12月28日 * @項(xiàng)目名稱: 安卓6.0運(yùn)行時(shí)權(quán)限 */ public class CheckPermissionsActivity extends AppCompatActivity implements ActivityCompat.OnRequestPermissionsResultCallback { /** * 需要進(jìn)行檢測(cè)的權(quán)限數(shù)組 這里只列舉了幾項(xiàng) 小伙伴可以根據(jù)自己的項(xiàng)目需求 來(lái)添加 */ protected String[] needPermissions = { Manifest.permission.ACCESS_COARSE_LOCATION,//定位權(quán)限 Manifest.permission.ACCESS_FINE_LOCATION,//定位權(quán)限 Manifest.permission.WRITE_EXTERNAL_STORAGE,//存儲(chǔ)卡寫入權(quán)限 Manifest.permission.READ_EXTERNAL_STORAGE,//存儲(chǔ)卡讀取權(quán)限 Manifest.permission.READ_PHONE_STATE//讀取手機(jī)狀態(tài)權(quán)限 }; private static final int PERMISSON_REQUESTCODE = 0; /** * 判斷是否需要檢測(cè),防止不停的彈框 */ private boolean isNeedCheck = true; @Override protected void onResume() { super.onResume(); if (isNeedCheck) { checkPermissions(needPermissions); } } /** * 檢查權(quán)限 */ private void checkPermissions(String... permissions) { List<String> needRequestPermissonList = findDeniedPermissions(permissions); if (null != needRequestPermissonList && needRequestPermissonList.size() > 0) { ActivityCompat.requestPermissions(this, needRequestPermissonList.toArray( new String[needRequestPermissonList.size()]), PERMISSON_REQUESTCODE); } } /** * 獲取權(quán)限集中需要申請(qǐng)權(quán)限的列表 * * @param permissions * @return * @since 2.5.0 */ private List<String> findDeniedPermissions(String[] permissions) { List<String> needRequestPermissonList = new ArrayList<String>(); for (String perm : permissions) { if (ContextCompat.checkSelfPermission(this, perm) != PackageManager.PERMISSION_GRANTED || ActivityCompat.shouldShowRequestPermissionRationale( this, perm)) { needRequestPermissonList.add(perm); } } return needRequestPermissonList; } /** * 檢測(cè)是否有的權(quán)限都已經(jīng)授權(quán) * * @param grantResults */ private boolean verifyPermissions(int[] grantResults) { for (int result : grantResults) { if (result != PackageManager.PERMISSION_GRANTED) { return false; } } return true; } @Override public void onRequestPermissionsResult(int requestCode, String[] permissions, int[] paramArrayOfInt) { if (requestCode == PERMISSON_REQUESTCODE) { if (!verifyPermissions(paramArrayOfInt)) { showMissingPermissionDialog(); isNeedCheck = false; } } } /** * 彈出對(duì)話框, 提示用戶手動(dòng)授權(quán) * */ private void showMissingPermissionDialog() { AlertDialog.Builder builder = new AlertDialog.Builder(this); builder.setTitle(R.string.notifyTitle); builder.setMessage(R.string.notifyMsg); // 拒絕授權(quán) 退出應(yīng)用 builder.setNegativeButton(R.string.cancel, new DialogInterface.OnClickListener() { @Override public void onClick(DialogInterface dialog, int which) { finish(); } }); //同意授權(quán) builder.setPositiveButton(R.string.setting, new DialogInterface.OnClickListener() { @Override public void onClick(DialogInterface dialog, int which) { startAppSettings(); } }); builder.setCancelable(false); builder.show(); } /** * 啟動(dòng)應(yīng)用的設(shè)置 * */ private void startAppSettings() { Intent intent = new Intent( Settings.ACTION_APPLICATION_DETAILS_SETTINGS); intent.setData(Uri.parse("package:" + getPackageName())); startActivity(intent); } @Override public boolean onKeyDown(int keyCode, KeyEvent event) { if (keyCode == KeyEvent.KEYCODE_BACK) { this.finish(); return true; } return super.onKeyDown(keyCode, event); }
string資源
<resources> <string name="app_name">My Library</string> <string name="notifyTitle">提示</string> <string name="notifyMsg">當(dāng)前應(yīng)用缺少必要權(quán)限。\n\n請(qǐng)點(diǎn)擊\"設(shè)置\"-\"權(quán)限\"-打開所需權(quán)限。</string> <string name="setting">設(shè)置</string> <string name="cancel">取消</string> </resources>
送上效果圖
注:更多關(guān)于Android權(quán)限控制的說(shuō)明可點(diǎn)擊此處查看Android權(quán)限操作說(shuō)明
更多關(guān)于Android相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《Android開發(fā)入門與進(jìn)階教程》、《Android視圖View技巧總結(jié)》、《Android編程之a(chǎn)ctivity操作技巧總結(jié)》、《Android文件操作技巧匯總》、《Android資源操作技巧匯總》及《Android控件用法總結(jié)》
希望本文所述對(duì)大家Android程序設(shè)計(jì)有所幫助。
- Android 如何實(shí)現(xiàn)動(dòng)態(tài)申請(qǐng)權(quán)限
- Android 拍照選擇圖片并上傳功能的實(shí)現(xiàn)思路(包含權(quán)限動(dòng)態(tài)獲取)
- 詳解Android開發(fā)錄音和播放音頻的步驟(動(dòng)態(tài)獲取權(quán)限)
- Android 6.0動(dòng)態(tài)權(quán)限及跳轉(zhuǎn)GPS設(shè)置界面的方法
- android6.0權(quán)限動(dòng)態(tài)申請(qǐng)框架permissiondispatcher的方法
- 關(guān)于Android 6.0權(quán)限的動(dòng)態(tài)適配詳解
- Android 6.0動(dòng)態(tài)權(quán)限申請(qǐng)教程
- Android6.0動(dòng)態(tài)申請(qǐng)權(quán)限所遇到的問題小結(jié)
- Android中不支持動(dòng)態(tài)申請(qǐng)權(quán)限的原因
- Android6.0獲取動(dòng)態(tài)權(quán)限代碼示例
相關(guān)文章
第1個(gè)Android應(yīng)用程序 Android制作簡(jiǎn)單單頁(yè)導(dǎo)航
這篇文章主要為大家詳細(xì)介紹了第1個(gè)Android應(yīng)用程序PhonewordApp:Android制作簡(jiǎn)單單頁(yè)導(dǎo)航,感興趣的小伙伴們可以參考一下2016-06-06詳解Android使用Gradle統(tǒng)一配置依賴管理
本篇文章主要介紹了詳解Android 使用 Gradle 統(tǒng)一配置依賴管理,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2018-01-01Android開發(fā)之DatePicker和TimePicker實(shí)現(xiàn)選擇日期時(shí)間功能示例
這篇文章主要介紹了Android開發(fā)之DatePicker和TimePicker實(shí)現(xiàn)選擇日期時(shí)間功能,結(jié)合實(shí)例形式分析了Android DatePicker和TimePicker組件的功能、常用函數(shù)、布局及日期時(shí)間選擇相關(guān)操作技巧,需要的朋友可以參考下2019-03-03OpenGL?Shader實(shí)現(xiàn)陰影遮罩效果
這篇文章主要介紹了如何利用OpenGL?Shader實(shí)現(xiàn)陰影遮罩效果,文中的示例代碼簡(jiǎn)潔易懂,對(duì)我們學(xué)習(xí)OpenGL有一定幫助,需要的可以參考一下2022-02-02Kotlin創(chuàng)建一個(gè)好用的協(xié)程作用域
這篇文章主要介紹了Kotlin創(chuàng)建一個(gè)好用的協(xié)程作用域,kotlin中使用協(xié)程,是一定要跟協(xié)程作用域一起配合使用的,否則可能協(xié)程的生命周期無(wú)法被準(zhǔn)確控制,造成內(nèi)存泄漏或其他問題2022-07-07Android 線程之自定義帶消息循環(huán)Looper的實(shí)例
這篇文章主要介紹了Android 線程之自定義帶消息循環(huán)Looper的實(shí)例的相關(guān)資料,希望通過(guò)本文能幫助到大家,需要的朋友可以參考下2017-10-10Android實(shí)現(xiàn)隨機(jī)生成驗(yàn)證碼
在登錄注冊(cè)軟件時(shí),經(jīng)常會(huì)要求填寫隨機(jī)驗(yàn)證碼,這篇文章為大家詳細(xì)主要介紹了Android實(shí)現(xiàn)隨機(jī)生成驗(yàn)證碼,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-08-08Android開發(fā)之在xml中設(shè)置自定義屬性的方法
下面小編就為大家分享一篇Android開發(fā)之在xml中設(shè)置自定義屬性的方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2018-01-01Android App中使用Pull解析XML格式數(shù)據(jù)的使用示例
這篇文章主要介紹了Android App中使用Pull解析XML格式數(shù)據(jù)的使用示例,Pull是Android中自帶的XML解析器,Java里也是一樣用:D需要的朋友可以參考下2016-04-04