自從Android6.0發(fā)布以來,在權(quán)限上做出了很大的變動,以前開發(fā)者只需要在manifest文件中將權(quán)限聲明就可以做該權(quán)限相關(guān)操作了香伴。一直覺得醬紫很不禮貌。比如有的惡意軟件突然調(diào)起相機(jī)拍攝用戶頭像上傳服務(wù)器脂新。比如軟件會悄悄地訪問用戶聯(lián)系人上傳服務(wù)器。這個隱私的數(shù)據(jù)怎么能隨便拿?
6.0系統(tǒng)以后,危險權(quán)限就需要軟件詢問用戶习蓬,通過允許后太能夠使用該功能纽什。不然呢措嵌,我不做申請直接用呢躲叼?那就直接崩吧。會報requires android.xxx permission企巢。
普通權(quán)限仍然只需要在manifest中聲明就可以枫慷,而危險權(quán)限必須請求用戶。
Normal Permissions
普通權(quán)限如常用的網(wǎng)絡(luò)浪规,wifi或听,設(shè)置時間,鬧鐘笋婿,NFC誉裆,震動等,
具體如下:
ACCESS_LOCATION_EXTRA_COMMANDS
ACCESS_NETWORK_STATE
ACCESS_NOTIFICATION_POLICY
ACCESS_WIFI_STATE
BLUETOOTH
BLUETOOTH_ADMIN
BROADCAST_STICKY
CHANGE_NETWORK_STATE
CHANGE_WIFI_MULTICAST_STATE
CHANGE_WIFI_STATE
DISABLE_KEYGUARD
EXPAND_STATUS_BAR
GET_PACKAGE_SIZE
INSTALL_SHORTCUT
INTERNET
KILL_BACKGROUND_PROCESSES
MODIFY_AUDIO_SETTINGS
NFC
READ_SYNC_SETTINGS
READ_SYNC_STATS
RECEIVE_BOOT_COMPLETED
REORDER_TASKS
REQUEST_IGNORE_BATTERY_OPTIMIZATIONS
REQUEST_INSTALL_PACKAGES
SET_ALARM
SET_TIME_ZONE
SET_WALLPAPER
SET_WALLPAPER_HINTS
TRANSMIT_IR
UNINSTALL_SHORTCUT
USE_FINGERPRINT
VIBRATE
WAKE_LOCK
WRITE_SYNC_SETTINGS
Dangerous Permissions
危險權(quán)限需涉及到用戶的隱私數(shù)據(jù)或資源缸濒,如讀取聯(lián)系人足丢,短信,讀取SD卡庇配,打電話斩跌,調(diào)攝像頭,定位等捞慌。
權(quán)限組
一系列相關(guān)權(quán)限耀鸦,如聯(lián)系人權(quán)限組包含 讀取、修改啸澡、獲取賬戶等權(quán)限袖订。
只要用戶授權(quán)了權(quán)限組中的一個,則系統(tǒng)會自動允許該組其他權(quán)限嗅虏。
具體如下:
SMS(短信)
???? SEND_SMS
???? RECEIVE_SMS
???? READ_SMS
???? RECEIVE_WAP_PUSH
???? RECEIVE_MMS
STORAGE(存儲卡)
???? READ_EXTERNAL_STORAGE
???? WRITE_EXTERNAL_STORAGE
CONTACTS(聯(lián)系人)
???? READ_CONTACTS
???? WRITE_CONTACTS
???? GET_ACCOUNTS
PHONE(手機(jī))
???? READ_PHONE_STATE
???? CALL_PHONE
???? READ_CALL_LOG
???? WRITE_CALL_LOG
???? ADD_VOICEMAIL
???? USE_SIP
???? PROCESS_OUTGOING_CALLS
CALENDAR(日歷)
???? READ_CALENDAR
???? WRITE_CALENDAR
CAMERA(相機(jī))
???? CAMERA
LOCATION(位置)
???? ACCESS_FINE_LOCATION
???? ACCESS_COARSE_LOCATION
SENSORS(傳感器)
???? BODY_SENSORS
MICROPHONE(麥克風(fēng))
???? RECORD_AUDIO
使用主要有4個方法:
1.檢查是否授予權(quán)限
ContextCompat.checkSelfPermission()
2.請求權(quán)限:
ActivityCompat.requestPermissions()
3.請求后的回調(diào):
onRequestPermissionsResult()
4.判斷用戶拒絕權(quán)限且選擇don't ask again著角,若勾選提示用戶去設(shè)置權(quán)限
以打電話為例,做法主要步驟:
1旋恼、在manifest中申請相關(guān)需要權(quán)限
<uses-permission android:name="android.permission.CALL_PHONE"/>
2吏口、檢查是否授予權(quán)限
if(ContextCompat.checkSelfPermission(getApplicationContext(), Manifest.permission.CALL_PHONE) != PackageManager.PERMISSION_GRANTED){
//權(quán)限被拒絕,申請權(quán)限
ActivityCompat.requestPermissions(PermissionTestActivity.this,new String[]{Manifest.permission.CALL_PHONE},1);
}else{
//權(quán)限同意冰更,撥打電話
callPhone();
}
3.調(diào)用打電話
private void callPhone(){
Intent intent = new Intent();
Uri data = Uri.parse("tel:" + "10086");
intent.setData(data);
startActivity(intent);
}
4.請求權(quán)限的回調(diào)
@Override
public void onRequestPermissionsResult(int requestCode, @NonNull String[] permissions, @NonNull int[] grantResults) {
super.onRequestPermissionsResult(requestCode, permissions, grantResults);
if(requestCode == 1){
if(grantResults[0] == PackageManager.PERMISSION_GRANTED){
//權(quán)限通過
callPhone();
}else{
Toast.makeText(PermissionTestActivity.this, "權(quán)限被拒絕", Toast.LENGTH_SHORT).show();
}
}
}
我們常會在app安裝好在歡迎頁面統(tǒng)一進(jìn)行權(quán)限申請产徊,該功能應(yīng)在BaseActivity中封裝:
//聲明一個數(shù)組,將需要的權(quán)限都放在其中
String[] permissions = new String[]{
Manifest.permission.CALL_PHONE,
Manifest.permission.WRITE_EXTERNAL_STORAGE
};
//存儲哪些權(quán)限未被授予
List<String> mPermissionList = new ArrayList<>();
for(int i=0;i<permissions.length;i++){
if(ContextCompat.checkSelfPermission(getApplicationContext(),
permissions[i]) != PackageManager.PERMISSION_GRANTED){
mPermissionList.add(permissions[i]);
}
}
//判斷是否為空蜀细,不為空的調(diào)用ActivityCompate.requestPermisson()授予權(quán)限舟铜。
if(!mPermissionList.isEmpty()){
String[] requestPermissions = mPermissionList.toArray(new String[mPermissionList.size()]);
ActivityCompat.requestPermissions(this,requestPermissions,REQUEST_CODE);
}
@Override
public void onRequestPermissionsResult(int requestCode, @NonNull String[] permissions, @NonNull int[] grantResults) {
super.onRequestPermissionsResult(requestCode, permissions, grantResults);
//權(quán)限處理回調(diào)中,判斷每個權(quán)限用戶是否授權(quán)奠衔;用戶拒絕授權(quán)的谆刨,還要判斷用戶是否勾選 don't ask again,勾選后不再彈框詢問
//ActivityCompat.shouldShowRequestPermissionRationale() 默認(rèn)為ture
if(requestCode == REQUEST_CODE){
for(int i=0;i<grantResults.length;i++){
if(grantResults[i] != PackageManager.PERMISSION_GRANTED){
boolean showRequestPermission = ActivityCompat.shouldShowRequestPermissionRationale(this,permissions[i]);
if(showRequestPermission){
//打開彈框再次詢問
}else{
}
}
}
}
}