『壹』 android 批量申請許可權
Android開發時,到6.0系統上之後,有的許可權就得申請才能用了。
Android將許可權分為正常許可權 和 危險許可權
詳細可參考: ( https://www.cnblogs.com/liupenglove/p/7102692.html )
網上也有很多參考例子,我這里總結下我的理解和用法
我們知道在Android6.0(SDK等級是23)以後有些許可權是需要動態申請的
然後這里主要記錄下如何同時動態申請多個許可權
我申請的許可權有三個:READ_EXTERNAL_STORAGE,WRITE_EXTERNAL_STORAGE,CAMERA,分別是讀,寫,還有相機許可權, INTERNET的話我發現靜態注冊也是可以的,當然以防萬一也可以加上.然後就是雖然是動態申請,但是還是需要在AndroidManifest.xml文件中進行靜態申請的:
然後是動態許可權申請
<1>首先聲明一個數組permissions,將所有需要申請的許可權都放在裡面
<2>創建一個mPermissionList,逐個判斷哪些許可權未授權,將未授權的許可權存儲到mPermissionList中
<3>聲明一個請求碼,在請求許可權的回調方法onRequestPermissionsResult中需要判斷使用
<4>進行許可權判斷和申請
<5>請求許可權後回調的方法,在許可權請求完成後做個判斷,是否完成了所有許可權的申請,
還有記錄一個坑
如果你的gradle文件中
targetSdkVersion 參數設置成了21的話 等於是用6.0以前的版本運行,這樣的話有可能導致無法動態申請許可權,這點需要特別注意下
如若有補充,留言區留下你的寶貴意見,謝謝!!!
『貳』 Android自定義許可權怎樣設置
Android自定義許可權
」包名+.+字元串「,而字元串通常為許可權名。
體現在AndroidManifest.xml文件中,則如下形式:
<permission android:name="com.wild.wildwithflower.myper"/>1
注意:自定義一個許可權必須用permission標簽,而不是uses-permission標簽;前者表示自定義一個許可權,後者表示要使用這個許可權。
即使是在自定義了該許可權的應用中要使用這個許可權,也必須用uses-permission聲明。否則,照樣不能使用該許可權。所以,如果在應用中自定義了一個許可權,又要使用這個許可權的話,AndroidManifest.xml中應有如下語句:
<permission android:name="com.wild.wildwithflower.myper"/>
<uses-permission android:name="com.wild.wildwithflower.myper"/>
『叄』 在android AndroidManifest.xml文件中怎樣設置訪問網路的許可權
Android訪問網路的許可權是android.permission.INTERNET。
聲明許可權的方式:
第一步:打開 AndroidManifest.xml文件
第二步:在application節點之前增加<uses-permission android:name=」android.permission.INTERNET」></uses-permission>
代碼中需要通過Thread來訪問網路,UI線程連接網路Android會拋出異常。
資料拓展:
Android是一種基於Linux的自由及開放源代碼的操作系統,主要使用於移動設備,如智能手機和平板電腦,由Google公司和開放手機聯盟領導及開發。尚未有統一中文名稱,中國大陸地區較多人使用「安卓」或「安致」。Android操作系統最初由Andy Rubin開發,主要支持手機。2005年8月由Google收購注資。2007年11月,Google與84家硬體製造商、軟體開發商及電信營運商組建開放手機聯盟共同研發改良Android系統。隨後Google以Apache開源許可證的授權方式,發布了Android的源代碼。第一部Android智能手機發布於2008年10月。Android逐漸擴展到平板電腦及其他領域上,如電視、數碼相機、游戲機等。2011年第一季度,Android在全球的市場份額首次超過塞班系統,躍居全球第一。 2013年的第四季度,Android平台手機的全球市場份額已經達到78.1%。2013年09月24日谷歌開發的操作系統Android在迎來了5歲生日,全世界採用這款系統的設備數量已經達到10億台。
『肆』 關於Android開發中如何添加Internet許可權的問題
在AndroidManifest.xml 文件中manifest標簽之後以內,application以外添加許可權<uses-permissionandroid:name="android.permission.INTERNET"/>
(4)android開發設置許可權擴展閱讀
一個許可權是一種限制,限制訪問代碼的一部分,或在設備上的數據。施加的限制,以保護關鍵數據和代碼可能被濫用,扭曲或損害了用戶體驗。
每個許可權確定一個唯一的標簽。標簽往往表示,這是限制的行動。
<permission-tree> 元素聲明為一組,將在代碼中定義的許可權的命名空間。和 <permission-group> 定義為一組的許可權(包括那些與艙單申報的標簽 <permission> 元素和那些宣布在別處)。它的影響只有許可權如何分組時,呈現給用戶。 <permission-group> 元素沒有指定屬於該組的許可權;它只是給該組的名稱。許可權被放置在該組分配的<permission> 元件的 permissionGroup, 屬性組的名稱 。
『伍』 android 開發通知管理許可權怎麼獲取
如果想修改這個許可權大概有三種方式:
1.通過代碼反射系統類實現
系統管理通知欄許可權的類是:GC: AppOpsService,所有設置界面、notificationManagerService都是通過它來實現對通知欄許可權的管理。但是setNode 方法會檢測 UPDATE_APP_OPS_STATS 許可權,這個許可權是系統許可權,一般應用無法取得(android 許可權列表:Android App Permissions)
2. 在 Root 手機上直接修改配置文件
在 AppOpsService 的代碼中可以看到它其實就是操作一個文件,把所有設置保存在裡面 (Android development: disable "show notification" programmatically with root permission?),由於這個文件只有取得 root 許可權的 app 才可以拿到,所以美團不具備這個可能。
3. 通過 accessibility 模擬用戶點擊
『陸』 android應用開發調用什麼方法可以進入到系統的許可權設置界面
1. 在應用程序的AndroidManifest.xml中的manifest節點中加入"android:sharedUserId="android.uid.system"這個屬性。
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
……
android:sharedUserId="android.uid.system" > <!--添加該屬性-->
<uses-permission android:name="android.permission.SHUTDOWN"/> <!--添加該許可權-->
……
</manifest>
ps:android:sharedUserId="android.uid.system" 將app提升到系統許可權,需要到源碼中編譯;還有關機許可權:android.permission.SHUTDOWN
『柒』 Android許可權機制
我們知道 Android 應用程序是沙箱隔離的,每個應用都有一個只有自己具有讀寫許可權的專用數據目錄。但是如果應用要訪問別人的組件或者一些設備上全局可訪問的資源,這時候許可權機制就能系統化地規范並強制各類應用程序的行為准則。
Android 安全性概覽
在 Android 中,一個許可權,本質上是一個字元串,一個可以表示執行特定操作的能力的字元串。比如說:訪問 SD 卡的能力,訪問通訊錄的能力,啟動或訪問一個第三方應用中的組件的能力。 許可權被授予了之後,首先會在內存和本地中有記錄,這在調用系統binder服務和其他應用組件時做鑒權依據,比如調用系統binder服務時會通過Binder.getCallingUid()拿到調用者的Uid,而Uid一般都是與應用包名一一對應的,再拿這個Uid到PMS里去查這個應用對應的許可權。 其次會按被授予的許可權將應用分到某個組。 可以參考 https://www.jianshu.com/p/a17c8bed79d9
自定義許可權的應用場景在於限制其它應用對本應用四大組件的訪問。具體用法可以參考 https://www.cnblogs.com/aimqqroad-13/p/8927179.html
pm list permissions -f 命令可以詳細查看 Android 所有預定義的許可權。
更詳細的許可權信息參考 https://developer.android.com/reference/android/Manifest.permission?hl=zh-cn#WRITE_EXTERNAL_STORAGE
可以看到一個許可權的信息包括:定義的包名、標簽、描述、 許可權組 和 保護級別 。
許可權根據設備的功能或特性分為多個組。如果應用已在相同許可權組中被授予另一危險許可權,系統將立即授予該許可權,如READ_CONTACTS和WRITE_CONTACTS。
SYSTEM_ALERT_WINDOW 和 WRITE_SETTINGS 由於其特殊性,其申請方式與其它許可權都不同。
其授予流程如下:
(關於 AppOpsManager 是什麼可以參考: https://segmentfault.com/a/1190000009214983 )
這里簡要分析下ActivityCompat#requestPermissions的流程:
更詳細的許可權授予流程源碼分析可以參考: https://segmentfault.com/a/1190000009214983
普通許可權: 清單文件中聲明即可。
危險許可權: 方式一: pm grant application_package android.permission.CHANGE_CONFIGURATION 方式二:appops set application_package permission_num 0/1
appops可以授予的許可權參考 android.app.AppOpsManager 中的聲明
系統簽名許可權: 方式一:將app遷移到system/priv-app目錄中。 方式二:看不懂,參考 https://blog.csdn.net/abcd_3344_abcd/article/details/50698759
android 4.4 訪問sd卡需要申請許可權。 您的應用在 Android 4.4 上運行時無法讀取外部存儲空間上的共享文件,除非您的應用具有 READ_EXTERNAL_STORAGE 許可權。也就是說,沒有此許可權,您無法再訪問 () 返回的目錄中的文件。但是,如果您僅需要訪問 getExternalFilesDir() 提供的您的應用特有目錄,那麼,您不需要 READ_EXTERNAL_STORAGE `許可權。
android 6.0 運行時許可權。 此版本引入了一種新的許可權模式,如今,用戶可直接在運行時管理應用許可權。這種模式讓用戶能夠更好地了解和控制許可權,同時為應用開發者精簡了安裝和自動更新過程。用戶可為所安裝的各個應用分別授予或撤銷許可權。 對於以 Android 6.0(API 級別 23)或更高版本為目標平台的應用,請務必在運行時檢查和請求許可權。要確定您的應用是否已被授予許可權,請調用新增的 checkSelfPermission() 方法。要請求許可權,請調用新增的 requestPermissions() 方法。即使您的應用並不以 Android 6.0(API 級別 23)為目標平台,您也應該在新許可權模式下測試您的應用。 如需了解有關在您的應用中支持新許可權模式的詳情,請參閱 使用系統許可權 。如需了解有關如何評估新模式對應用的影響的提示,請參閱 許可權最佳做法 。
android 7.+ 應用間共享文件要使用FileProvider。 對於面向 Android 7.0 的應用,Android 框架執行的 StrictMode API 政策禁止在您的應用外部公開 file://URI。如果一項包含文件 URI 的 intent 離開您的應用,則應用出現故障,並出現 FileUriExposedException 異常。 要在應用間共享文件,您應發送一項 content:// URI,並授予 URI 臨時訪問許可權。進行此授權的最簡單方式是使用 FileProvider `類。如需了解有關許可權和共享文件的詳細信息,請參閱 共享文件 。
android 8.+
同一許可權組的許可權在被授予了之後也需要顯式的再申請一次。
在 Android 8.0 之前,如果應用在運行時請求許可權並且被授予該許可權,系統會錯誤地將屬於同一許可權組並且在清單中注冊的其他許可權也一起授予應用。 對於針對 Android 8.0 的應用,此行為已被糾正。系統只會授予應用明確請求的許可權。然而,一旦用戶為應用授予某個許可權,則所有後續對該許可權組中許可權的請求都將被自動批准。 例如,假設某個應用在其清單中列出 READ_EXTERNAL_STORAGE 和 WRITE_EXTERNAL_STORAGE 。應用請求 READ_EXTERNAL_STORAGE ,並且用戶授予了該許可權。如果該應用針對的是 API 級別 24 或更低級別,系統還會同時授予 WRITE_EXTERNAL_STORAGE ,因為該許可權也屬於同一 STORAGE 許可權組並且也在清單中注冊過。如果該應用針對的是 Android 8.0,則系統此時僅會授予 READ_EXTERNAL_STORAGE ;不過,如果該應用後來又請求 WRITE_EXTERNAL_STORAGE ,則系統會立即授予該許可權,而不會提示用戶。
android 9
隱私許可權變更。
為了增強用戶隱私,Android 9 引入了若干行為變更,如限制後台應用訪問設備感測器、限制通過 Wi-Fi 掃描檢索到的信息,以及與通話、手機狀態和 Wi-Fi 掃描相關的新許可權規則和許可權組。
android 10
隱私權變更。
外部存儲訪問許可權范圍限定為應用文件和媒體,在後台運行時訪問設備位置信息需要許可權,針對從後台啟動 Activity 的限制等。
android 11
隱私許可權變更。
更詳細的版本變更請參考 https://developer.android.com/preview/privacy?hl=zh-cn