Android 장치 프라이버시 가 져 오기 6.0 권한 관리 무시
(1).MIUI 등 일부 국산 맞 춤 형 시스템 도 관리 권한 이 있 고 관련 api 가 없 기 때문에 사용자 가 연락처 등 프라이버시 를 가 져 올 수 있 는 지 판단 할 수 없습니다.Android 6.0 이후 추가 권한 관 리 는 공식 api 를 통 해 사용자 의 운행 상 태 를 판단 할 수 있 습 니 다.
(2).targetSdkVersion 을 23 으로 지정 하거나 실행 할 때 필요 한 권한 을 요청 해 야 합 니 다.이것 은 매우 중요 합 니 다.많은 개발 자 들 이 targetSdkVersion 을 최신 으로 치 솟 은 후에 자신의 app 이 미 친 듯 이 무 너 진 것 을 발 견 했 습 니 다.이것 은 실행 시 권한 요청 을 수행 하 는 코드 가 없 기 때 문 입 니 다.targeting API 를 23 또는 그 후의 app 으로 Google Play 에 발 표 했 을 때 더욱 문제 가 됩 니 다.그 apk 의 targeting API 를 더 빠 른 버 전 으로 바로 바 꿀 수 없습니다.
권한 분석
안 드 로 이 드 6.0 부터 권한 은 일반 권한 과 허가 권한 으로 나 뉜 다.허가 권한 은 그룹 으로 분류 되 고 하나의 권한 이 권한 을 부여 한 후에 이 그룹의 권한 은 모두 사용 할 수 있 습 니 다.
(1)일반 권한
xml 로 만 신청 하면 됩 니 다.사용 방법 은 이전 6.0 이전 과 같 습 니 다.설치 애플 리 케 이 션 을 사용 할 때 기본적으로 허 가 를 받 습 니 다.
(2)허가 권한
실행 가능$adb shell pm list permissions-d-g
같은 그룹의 모든 권한 이 권한 을 수 여 받 았 고 다른 권한 도 자동 으로 권한 을 수 여 받 았 습 니 다.예 를 들 어 일단 WRITECONTACTS 권한 이 부여 되 었 습 니 다.app 에 도 READ 가 있 습 니 다.CONTACTS 와 GETACCOUNTS 입 니 다.
원본 코드 에서 권한 을 검사 하고 요청 하 는 방법 은 Activity 의 checkSelfPermission 과 requestPermissions 입 니 다.이 방법 들 은 api 23 이 도입 되 었 습 니 다.
관련 방법
(1).ContextCompat.checkSelfPermission()
응용 프로그램 이 이 권한 을 가지 고 있 는 지 확인 합 니 다.권한 을 수 여 받 은 반환 값 은 PERMISSION 입 니 다.GRANTED,그렇지 않 으 면 PERMISSION 으로 돌아 갑 니 다.DENIED
(2).ActivityCompat.requestPermissions()
팝 업 요청 권한 부여 대화 상 자 를 M 이전 버 전에 서 호출 합 니 다.OnRequestPermissions ResultCallback 이 직접 호출 되 고 정확 한 PERMISSION 을 가지 고 있 습 니 다.GRANTED 혹은 PERMISSIONDENIED 。
(3).AppCompatActivity.onRequestPermissionsResult()
이 방법 은 Activity 의 OnActivity Result()와 유사 한 리 셋 방법 으로 권한 수 여 를 요청 한 반환 값 을 받 습 니 다.
//
if (Build.VERSION.SDK_INT >= 23) {
//
int checkCallPhonePermission = ContextCompat.checkSelfPermission(getApplicationContext(), permission);
if (checkCallPhonePermission != PackageManager.PERMISSION_GRANTED) {
//
ActivityCompat.requestPermissions(BaseActivity.this, new String[]{permission}, id);
return;
}
@Override
public void onRequestPermissionsResult(int requestCode, @NonNull String[] permissions, @NonNull int[] grantResults) {
super.onRequestPermissionsResult(requestCode, permissions, grantResults);
if (grantResults[0] == PackageManager.PERMISSION_GRANTED) {
//TODO:
} else {
//TODO:
}
}
(4).패키지
public class BaseActivity extends AppCompatActivity {
private Map<Integer, Runnable> allowablePermissionRunnables = new HashMap<>();
private Map<Integer, Runnable> disallowablePermissionRunnables = new HashMap<>();
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
}
/**
*
* @param id id
* @param permission
* @param allowableRunnable
* @param disallowableRunnable
*/
protected void requestPermission(int id, String permission, Runnable allowableRunnable, Runnable disallowableRunnable) {
if (allowableRunnable == null) {
throw new IllegalArgumentException("allowableRunnable == null");
}
allowablePermissionRunnables.put(id, allowableRunnable);
if (disallowableRunnable != null) {
disallowablePermissionRunnables.put(id, disallowableRunnable);
}
//
if (Build.VERSION.SDK_INT >= 23) {
//
int checkCallPhonePermission = ContextCompat.checkSelfPermission(getApplicationContext(), permission);
if (checkCallPhonePermission != PackageManager.PERMISSION_GRANTED) {
//
ActivityCompat.requestPermissions(BaseActivity.this, new String[]{permission}, id);
return;
} else {
allowableRunnable.run();
}
} else {
allowableRunnable.run();
}
}
@Override
public void onRequestPermissionsResult(int requestCode, @NonNull String[] permissions, @NonNull int[] grantResults) {
super.onRequestPermissionsResult(requestCode, permissions, grantResults);
if (grantResults[0] == PackageManager.PERMISSION_GRANTED) {
Runnable allowRun = allowablePermissionRunnables.get(requestCode);
allowRun.run();
} else {
Runnable disallowRun = disallowablePermissionRunnables.get(requestCode);
disallowRun.run();
}
}
}
public class MainActivity extends BaseActivity implements View.OnClickListener{
private Button btCallPhone;
private Button btContact;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
btCallPhone = (Button) findViewById(R.id.call_phone);
btContact = (Button) findViewById(R.id.contact);
btCallPhone.setOnClickListener(this);
btContact.setOnClickListener(this);
}
@Override
public void onClick(View v) {
if(v == btCallPhone){
//
requestPermission(1, Manifest.permission.CALL_PHONE, new Runnable() {
@Override
public void run() {
callPhone();
}
}, new Runnable() {
@Override
public void run() {
callPhoneDenied();
}
});
}else if(v == btContact){
//
requestPermission(2, Manifest.permission.WRITE_CONTACTS, new Runnable() {
@Override
public void run() {
readContact();
}
}, new Runnable() {
@Override
public void run() {
readContactDenied();
}
});
}
}
private void callPhone() {
Toast.makeText(MainActivity.this, "CALL_PHONE OK", Toast.LENGTH_SHORT)
.show();
}
private void callPhoneDenied() {
Toast.makeText(MainActivity.this, "CALL_PHONE Denied", Toast.LENGTH_SHORT)
.show();
}
private void readContact() {
ContentResolver cr = getContentResolver();
String str[] = {ContactsContract.CommonDataKinds.Phone.CONTACT_ID, ContactsContract.CommonDataKinds.Phone.DISPLAY_NAME, ContactsContract.CommonDataKinds.Phone.NUMBER,
ContactsContract.CommonDataKinds.Phone.PHOTO_ID};
Cursor cur = cr.query(
ContactsContract.CommonDataKinds.Phone.CONTENT_URI, str, null,
null, null);
int count = cur.getCount();
cur.close();
Toast.makeText(MainActivity.this, String.format(" %s ", count), Toast.LENGTH_SHORT)
.show();
}
private void readContactDenied() {
Toast.makeText(MainActivity.this, "Contact Denied", Toast.LENGTH_SHORT)
.show();
}
}
이상 은 본문의 전체 내용 이 므 로 여러분 의 학습 에 도움 이 되 기 를 바 랍 니 다.
이 내용에 흥미가 있습니까?
현재 기사가 여러분의 문제를 해결하지 못하는 경우 AI 엔진은 머신러닝 분석(스마트 모델이 방금 만들어져 부정확한 경우가 있을 수 있음)을 통해 가장 유사한 기사를 추천합니다:
Bitrise에서 배포 어플리케이션 설정 테스트하기이 글은 Bitrise 광고 달력의 23일째 글입니다. 자체 또는 당사 등에서 Bitrise 구축 서비스를 사용합니다. 그나저나 며칠 전 Bitrise User Group Meetup #3에서 아래 슬라이드를 발표했...
텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
CC BY-SA 2.5, CC BY-SA 3.0 및 CC BY-SA 4.0에 따라 라이센스가 부여됩니다.