使用 Kotlin 开发 Android 应用获取国家/地区信息
获取设备国家/地区代码
通过 Locale
类可以直接获取设备当前设置的国家/地区代码:
kotlin
val countryCode = Locale.getDefault().country
此方法返回 ISO 3166-1 标准的两位字母国家代码(如 "US" 表示美国)。
使用 TelephonyManager 获取 SIM 卡信息
对于需要获取 SIM 卡所属国家信息的情况:
kotlin
val telephonyManager = getSystemService(Context.TELEPHONY_SERVICE) as TelephonyManager
val simCountry = telephonyManager.simCountryIso?.toUpperCase()
注意:需要添加权限到 AndroidManifest.xml:
XML
<uses-permission android:name="android.permission.READ_PHONE_STATE" />
通过网络 IP 地址定位
可以使用第三方 API 获取基于 IP 的国家信息:
kotlin
suspend fun getCountryByIP(): String? {
val url = "https://ipapi.co/json/"
return try {
val response = withContext(Dispatchers.IO) {
URL(url).readText()
}
val jsonObject = JSONObject(response)
jsonObject.getString("country_name")
} catch (e: Exception) {
null
}
}
使用 Android 位置服务
结合 LocationManager 获取地理位置信息:
kotlin
val locationManager = getSystemService(Context.LOCATION_SERVICE) as LocationManager
val locations = locationManager.getProviders(true)
var country: String? = null
locations.forEach { provider ->
val location = locationManager.getLastKnownLocation(provider)
location?.let {
val geocoder = Geocoder(this, Locale.getDefault())
val addresses = geocoder.getFromLocation(it.latitude, it.longitude, 1)
addresses?.firstOrNull()?.countryName?.let { name ->
country = name
}
}
}
需要添加以下权限:
XML
<uses-permission android:name="android.permission.ACCESS_COARSE_LOCATION" />
<uses-permission android:name="android.permission.ACCESS_FINE_LOCATION" />
显示国家信息
将获取到的国家信息显示在 UI 上:
kotlin
binding.countryTextView.text = when {
!countryCode.isNullOrEmpty() -> "Device Country: $countryCode"
!simCountry.isNullOrEmpty() -> "SIM Country: $simCountry"
else -> "Country not detected"
}
处理运行时权限
对于需要权限的方法,需要检查并请求权限:
kotlin
if (ContextCompat.checkSelfPermission(this, Manifest.permission.ACCESS_FINE_LOCATION)
!= PackageManager.PERMISSION_GRANTED) {
ActivityCompat.requestPermissions(
this,
arrayOf(Manifest.permission.ACCESS_FINE_LOCATION),
LOCATION_PERMISSION_REQUEST_CODE
)
}
多方法组合策略
建议采用组合策略提高准确性:
- 优先尝试从 SIM 卡获取
- 回退到设备区域设置
- 最后尝试网络定位
- 可添加用户手动选择功能作为备用方案