如何用 Kotlin 在 Android 手机开发一个应用程序获取国家或地区信息

使用 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
    )
}
多方法组合策略

建议采用组合策略提高准确性:

  1. 优先尝试从 SIM 卡获取
  2. 回退到设备区域设置
  3. 最后尝试网络定位
  4. 可添加用户手动选择功能作为备用方案
相关推荐
恋猫de小郭25 分钟前
Flutter Zero 是什么?它的出现有什么意义?为什么你需要了解下?
android·前端·flutter
工程师老罗7 小时前
如何在Android工程中配置NDK版本
android
Libraeking10 小时前
破壁行动:在旧项目中丝滑嵌入 Compose(混合开发实战)
android·经验分享·android jetpack
市场部需要一个软件开发岗位11 小时前
JAVA开发常见安全问题:Cookie 中明文存储用户名、密码
android·java·安全
JMchen12312 小时前
Android后台服务与网络保活:WorkManager的实战应用
android·java·网络·kotlin·php·android-studio
七夜zippoe13 小时前
脉向AI|当豆包手机遭遇“全网封杀“:GUI Agent是通向AGI的必经之路吗?
人工智能·ai·智能手机·agent·gui
crmscs13 小时前
剪映永久解锁版/电脑版永久会员VIP/安卓SVIP手机永久版下载
android·智能手机·电脑
lichensun13 小时前
2026美赛A题智能手机电池耗电建模—思路全解析(含具体模型和代码)
数学建模·智能手机
localbob13 小时前
杀戮尖塔 v6 MOD整合版(Slay the Spire)安卓+PC端免安装中文版分享 卡牌肉鸽神作!杀戮尖塔中文版,电脑和手机都能玩!杀戮尖塔.exe 杀戮尖塔.apk
android·杀戮尖塔apk·杀戮尖塔exe·游戏分享
IT技术分享社区13 小时前
手机投屏到电视上,4种不同的方法,一起来了解一下
智能手机·投屏·手机技巧