ppeper
by ppeper
2 분 소요

Categories

Tags

Android Permission

안드로이드에서는 특정한 앱을 실행하기 위해서는 권한이 필요하다. 안드로이드 마시멜로 버전(API 23) 이전에는 앱 설치시 모든 권한이 요청되었지만 이후에는 일반 권한, 위험 권한 으로 나눠게 되었다.

따라서 API 23 이후 버전의 기기에서는 위험 권한은 기능이 동작할 때 사용자가 직접 권한을 허락하도록 런타임에 권한을 설정 해주어야 한다.

위에 해당하는 기능들은 런타임시 권한을 설정해 주어야 한다. 만약 권한이 없다면 앱을 종료시켜버린다.😅

✅권한 체크

ContextCompat.checkSelfPermission(컨텍스트(), 퍼미션정보) 메서드를 사용하여 앱에 이미 권한을 부여 받았는지 확인 할 수 있다.

이 메서드는 앱에 권한 여부에 따라 PERMISSION_GRANTED 또는 PERMISSION_DENIED를 반환 한다.

👉권한 요청

Activity.requestPermissions(컨텍스트(),퍼미션 리스트,요청값) 메서드를 사용하여 퍼미션 정보들과 요청을 보내게 되면 해당 요청 값이 반환된다.

📄요청 결과

요청 결과는 onRequestPermissionsResult() 가 호출된다. 이 메서드는 요청 값을 확인하여 권한 상태에 따라 결과를 처리 한다.

AndroidManifest.xml에 위치 권한을 추가한다.

<!-- GPS 센서로 측정-->
<uses-permission android:name="android.permission.ACCESS_FINE_LOCATION"/>
<!-- 네트워크로 측정-->
<uses-permission android:name="android.permission.ACCESS_COARSE_LOCATION" />
// 받으려는 권한들
val RUNTIME_PERMISSIONS = arrayOf(
    Manifest.permission.ACCESS_COARSE_LOCATION,
    Manifest.permission.ACCESS_FINE_LOCATION
)
// 권한 요청 코드
val PERMISSION_REQUEST_CODE = 8;

// 권한 체크
val coarseResult = ContextCompat.checkSelfPermission(this, Manifest.permission.ACCESS_COARSE_LOCATION)
val fineResult = ContextCompat.checkSelfPermission(this, Manifest.permission.ACCESS_FINE_LOCATION)

// 권한 획득했는지 체크
if (coarseResult == PackageManager.PERMISSION_GRANTED &&
        fineResult == PackageManager.PERMISSION_GRANTED ){
    // 권한이 확인된 이후 작업
} else {
    //권한이 없을때 권한 요청창 띄우기
    ActivityCompat.requestPermissions(this, RUNTIME_PERMISSIONS, PERMISSION_REQUEST_CODE);
}

// 요청 결과
override fun onRequestPermissionsResult(
    requestCode: Int,
    permissions: Array<String>,
    grantResults: IntArray
) {
    super.onRequestPermissionsResult(requestCode, permissions, grantResults)
    when (requestCode) {
        PERMISSION_REQUEST_CODE -> {
            var results = true
            Log.d(TAG, "onRequestPermissionsResult: 건수 : $grantResults")
            if (grantResults.size > 0) {
                for (temp in grantResults) {
                    if (temp == PackageManager.PERMISSION_DENIED) { //전체 권한 grant확인
                        results = false
                        break
                    }
                }
            }

            if (results) { // 전체 권한 획득된 경우.
                Toast.makeText(this, "모든 권한이 허가되었습니다.", Toast.LENGTH_SHORT).show()
            } else { // 거절된 경우
                Toast.makeText(this, "권한이 필요합니다.", Toast.LENGTH_SHORT).show()
            }
        }
    }
}

안드로이드에서 onRequestPermissionsResult() 메소드는 deprecated 되어 registerForActivityResult를 사용하도록 권고한다.

권한 설정을 하기 위해선 ActivityResultConstracts의 RequestPermission() 으로 단일 권한을 요청할 수 있고, RequestMultiplePermissions() 으로 복수 권한을 요청할 수 있다.

단일 권한의 콜백으로는 Boolean 값으로 권한 허용 여부를 알 수 있고, 복수 권한의 경우 Map<String, Boolean> 으로 각 권한들의 key에 따라 구분 된다.

ActivityResultConstracts 사용하기

// 단일 권한
val RUNTIME_PERMISSION = Manifest.permission.ACCESS_COARSE_LOCATION,

val requestPermission = registerForActivityResult(
    ActivityResultContracts.RequestPermission()) { isGrant ->
    when (isGrant) {
        true -> {
            Toast.makeText(this,"권한 허가",Toast.LENGTH_SHORT).show()
        }
        false -> {
            Toast.makeText(this,"권한 불가",Toast.LENGTH_SHORT).show()
        }
    }
}

// 복수 권한
val RUNTIME_PERMISSIONS = arrayOf(
    Manifest.permission.ACCESS_COARSE_LOCATION,
    Manifest.permission.ACCESS_FINE_LOCATION
)

val requestMultiplePermission = registerForActivityResult(
    ActivityResultContracts.RequestMultiplePermissions()) { result ->
    // result -> Map<String, Boolean>
    for ((permission, isGrant) in result) {
        Toast.makeText(this, "$permission = $isGrant", Toast.LENGTH_SHORT).show()
    }
}

// 권한 획득했는지 체크
if (coarseResult == PackageManager.PERMISSION_GRANTED &&
        fineResult == PackageManager.PERMISSION_GRANTED ){
    // 권한이 확인된 이후 작업
} else {
    //권한이 없을때 권한 요청창 띄우기
    // ActivityCompat.requestPermissions(this, RUNTIME_PERMISSIONS, PERMISSION_REQUEST_CODE);

    // 단일 권한
    requestPermission.launch(RUNTIME_PERMISSION)
    // 복수 권한
    requestMultiplePermission.launch(RUNTIME_PERMISSIONS)
}

Toast 메시지로 복수 권한에 대한 결과를 확인 해 볼 수 있다.


References