原文: Android 获取设备的CPU型号和设备型号-Stars-One的杂货小窝

之前整的项目的总结信息,可能不太全,凑合着用吧,代码在最下面一节

CPU型号数据

  • 华为: ro.mediatek.platform
  • vivo: ro.vivo.product.platform
  • oppo: ro.board.platform 或 ro.product.board
  • 三星: ro.board.platform
  • 小米: ro.soc.model

小米:

GKI 2.0 之前,/proc/cpuinfo 中包含 Hardware 相关信息,应用可以从中读取 cpu 型号信息;

GKI 2.0 之后,/proc/cpuinfo 中不再包含 Hardware 相关信息,应用无法从中读取到 cpu 型号信息,需要从 android.os.SystemProperties 中读取 ro.soc.model 属性信息。参考说明:关于 GKI 内核版本说明

建议优先从 android.os.SystemProperties 中读取 ro.soc.model 属性信息,若此属性信息为空,则再从 /proc/cpuinfo 中读取 Hardware 信息即可。

1.查看所有配置信息:

adb shell getprop

2.查看指定配置信息:

adb shell getprop [key]

如:查看设备型号:adb shell getprop “ro.product.model”

可以通过adb shell命令来得到数据或者通过反射

//通过shell命令
val cmdResult = ShellUtils.execCmd("getprop", false) //通过反射
val classType = Class.forName("android.os.SystemProperties")
val method = classType.getDeclaredMethod("get", String::class.java)
val result = method.invoke(classType, "ro.vivo.product.platform") as String //SM6225

设备型号

vivo

[ro.vivo.os.build.display.id]: [OriginOS 1.0]
[ro.vivo.os.name]: [Funtouch]
[ro.vivo.os.version]: [12.0]
[ro.vivo.market.name]: [vivo Y32]

小米

新增ro.product.marketname属性,值为手机设备名(上市机型名称);

历史已发布手机上设备型号的属性ro.product.model依然有效,以后新发布的机型上不再生效。请开发者及时适配。

建议应用优先读取属性ro.product.marketname,如果返回值不为空,这个值就是手机设备型号。如果此属性返回值为空,则读取之前的属性ro.product.model值

public static String getDeviceName() {
String deviceName = "";
try {
Class SystemProperties = Class.forName("android.os.SystemProperties");
Method get = SystemProperties.getDeclaredMethod("get", String.class, String.class);
deviceName = (String) get.invoke(SystemProperties, "ro.product.marketname", "");
if (TextUtils.isEmpty(deviceName)) {
deviceName = (String) get.invoke(SystemProperties, "ro.product.model", "");
}
} catch (InvocationTargetException | NoSuchMethodException | IllegalAccessException | ClassNotFoundException e) {
e.printStackTrace();
}
return deviceName;
}

工具类源码

点击展开代码
package com.hlfonts.richway.widget.tool

import android.os.Build
import android.text.TextUtils
import com.blankj.utilcode.util.ShellUtils
import java.util.* /**
* 工具类参考 https://blog.csdn.net/convex1009848621/article/details/120767000
*/
object CustomOSUtils {
/**
* customOS默认值为"",如果识别出的手机厂商是预知的,会被重新赋值,如果未识别到该机型则返回原生安卓信息
*/
private var customOS: String? = "" /**
* CustomOSVersion默认值为"",如果识别出的手机厂商是预知的,会被重新赋值成对应rom系统的版本号
* 如果未识别到该机型则返回原生安卓信息
*/
private var customOSVersion: String? = "" /**
* HarmonyOS 系统输出的
* 格式:2.0.0
*/
private const val KEY_HARMONYOS_VERSION_NAME = "hw_sc.build.platform.version" /**
* EMUI系统输出的
* 格式:EmotionUI_8.0.0
*/
private const val KEY_EMUI_VERSION_NAME = "ro.build.version.emui" /**
* MagicUI系统输出的
* 格式:3.1.0
*/
private const val KEY_MAGICUI_VERSION = "ro.build.version.magic" /**
* MIUI系统输出的
* 格式:V12
*/
private const val KEY_MIUI_VERSION_NAME = "ro.miui.ui.version.name" /**
* OPPO手机ColorOS系统输出的
* 格式:9
*/
private const val KEY_COLOROS_VERSION_NAME = "ro.build.version.opporom" /**
* VIVO手机系统输出的
* name格式:funtouch
* version格式: 9
*/
private const val KEY_VIVO_VERSION_NAME = "ro.vivo.os.name"
private const val KEY_VIVO_VERSION = "ro.vivo.os.version" /**
* OonPlus手机系统输出的
* 格式:Hydrogen OS 11.0.7.10.KB05
*/
private const val KEY_ONEPLUS_VERSION_NAME = "ro.rom.version" /**
* 魅族手机系统输出的
*/
private const val KEY_FLYME_VERSION_NAME = "ro.build.display.id" /**
* nubia手机系统输出的
*/
private const val KEY_NUBIA_VERSION_NAME = "ro.build.nubia.rom.name"
private const val KEY_NUBIA_VERSION_CODE = "ro.build.nubia.rom.code" /**
* 传入获取手机系统属性的key,可以得到rom系统版本信息
* @param key
* @return
*/
private fun getSystemPropertyValue(key: String): String {
val cmd = """
getprop "$key"
""".trimIndent()
val cmdResult = ShellUtils.execCmd(cmd, false)
return cmdResult.successMsg?:"" } /**
* 判断是否是华为鸿蒙系统,能否识别荣耀鸿蒙未知
*
* @return
*/
private fun isHarmonyOS(): Boolean {
val value = getHarmonyOsBrand()
return TextUtils.isEmpty(value).not()
} private fun getHarmonyOsBrand(): String {
var result = ""
kotlin.runCatching {
val classType = Class.forName("com.huawei.system.BuildEx")
val getMethod = classType.getMethod("getOsBrand")
result = getMethod.invoke(classType) as String
}
return result
} /**
* 通过手机品牌信息获取手机rom系统+系统版本号
* @param phoneBrand
* @return 如 flyme 5.0
*/
fun getPhoneSystemName(): String {
if (TextUtils.isEmpty(customOS)) {
setCustomOSInfo()
}
return "$customOS $customOSVersion"
} private val isMagicUI: Boolean = false /**
* 通过手机品牌信息获取手机rom系统
* @param phoneBrand
* @return
*/
fun getCustomOS(): String? {
if (TextUtils.isEmpty(customOS)) {
setCustomOSInfo()
}
return customOS
} /**
* 通过手机品牌信息获取手机rom系统版本号
* @param phoneBrand
* @return
*/
fun getCustomOSVersion(): String? {
if (TextUtils.isEmpty(customOS)) {
setCustomOSInfo()
}
return customOSVersion
} /**
* 删除字符串中的空格并全部转成大写
* @param str
* @return
*/
private fun deleteSpaceAndToUpperCase(str: String): String {
return if (TextUtils.isEmpty(str)) {
""
} else str.replace(" ".toRegex(), "").uppercase(Locale.getDefault())
} private fun setCustomOSInfo() {
// 示例: xiaomi
val phoneBrand = Build.BRAND
try {
when (deleteSpaceAndToUpperCase(phoneBrand)) {
"HUAWEI" -> if (isHarmonyOS()) {
customOSVersion = getSystemPropertyValue(KEY_HARMONYOS_VERSION_NAME)
customOS = "Harmony"
} else {
customOS = "EMUI"
customOSVersion = getSystemPropertyValue(KEY_EMUI_VERSION_NAME)
}
"HONOR" -> if (isHarmonyOS()) {
customOS = "Harmony"
if (!TextUtils.isEmpty(getSystemPropertyValue(KEY_HARMONYOS_VERSION_NAME))) {
customOSVersion = getSystemPropertyValue(KEY_HARMONYOS_VERSION_NAME)
} else {
customOSVersion = ""
}
} else if (!TextUtils.isEmpty(getSystemPropertyValue(KEY_MAGICUI_VERSION))) {
customOS = "MagicUI"
customOSVersion = getSystemPropertyValue(KEY_MAGICUI_VERSION)
} else {
//格式:EmotionUI_8.0.0
customOS = "EMUI"
customOSVersion = getSystemPropertyValue(KEY_EMUI_VERSION_NAME)
}
"XIAOMI", "REDMI" -> {
//格式:MIUIV12
customOS = "MIUI"
customOSVersion = getSystemPropertyValue(KEY_MIUI_VERSION_NAME)
}
"REALME", "OPPO" -> {
//格式:ColorOSV2.1
customOS = "ColorOS"
customOSVersion = getSystemPropertyValue(KEY_COLOROS_VERSION_NAME)
}
"VIVO" -> {
val result = getSystemPropertyValue("ro.vivo.os.build.display.id")
if (result.isNotBlank()) {
//格式: OriginOS 1.0
val arr = result.split(" ")
customOS = arr.first()
customOSVersion = arr.last()
} else {
//格式:Funtouch9
customOS = "Funtouch"
customOSVersion = getSystemPropertyValue(KEY_VIVO_VERSION)
}
}
"ONEPLUS" -> {
//格式:Hydrogen OS 11.0.7.10.KB05
customOS = "Hydrogen"
customOSVersion = getSystemPropertyValue(KEY_ONEPLUS_VERSION_NAME)
}
"MEIZU" -> {
//格式:Flyme 6.3.5.1G
customOS = "Flyme"
customOSVersion = getSystemPropertyValue(KEY_FLYME_VERSION_NAME)
}
"NUBIA" -> {
//格式:nubiaUIV3.0
customOS = getSystemPropertyValue(KEY_NUBIA_VERSION_NAME)
customOSVersion = getSystemPropertyValue(KEY_NUBIA_VERSION_CODE)
}
else -> {
customOS = "Android"
customOSVersion = Build.VERSION.RELEASE
}
}
} catch (e: Exception) {
customOS = "Android"
customOSVersion = Build.VERSION.RELEASE
}
}
}

用法:

CustomOSUtils.getPhoneSystemName()

参考

Android 获取设备的CPU型号和设备型号的更多相关文章

  1. android获取设备唯一标示

    概述 有时需要对用户设备进行标识,所以希望能够得到一个稳定可靠并且唯一的识别码.虽然Android系统中提供了这样设备识别码,但是由于Android系统版本.厂商定制系统中的Bug等限制,稳定性和唯一 ...

  2. Android 设备的CPU类型(通常称为”ABIs”)

    armeabiv-v7a: 第7代及以上的 ARM 处理器.2011年15月以后的生产的大部分Android设备都使用它. arm64-v8a: 第8代.64位ARM处理器,很少设备,三星 Galax ...

  3. Android 获取设备唯一标识码

    概述 有时需要对用户设备进行标识,所以希望能够得到一个稳定可靠并且唯一的识别码.虽然Android系统中提供了这样设备识别码,但是由于Android系统版本.厂商定制系统中的Bug等限制,稳定性和唯一 ...

  4. 【转】 android获取设备唯一标识完美解决方案

    <p style="margin: 10px auto; padding-top: 0px; padding-bottom: 0px; color: rgb(51, 51, 51);  ...

  5. 获取Android设备的唯一识别码|设备号|序号|UUID

    如何获取一个能唯一标识每台Android设备的序号? 这个问题有很多答案,但是他们中的大部分只在某些情况下有效. 根据测试: 所有的设备都可以返回一个 TelephonyManager.getDevi ...

  6. 获取当前设备的CPU个数

    public class Test { public static void main(String[] args) { //获取当前设备的CPU个数 int availableProcessors ...

  7. Android 获取手机(ios,android)的设备唯一码(mac地址, IMEI)

    { /*获取手机(ios,android)的设备唯一码(mac地址, IMEI)2018年02月16日 ⁄ 综合 ⁄ 共 2697字 ⁄ 字号 小 中 大 ⁄ 评论关闭 app中总会用到客户端下载量数 ...

  8. android -------- 获取手机设备信息

    最近在开发中,需要用到一些系统信息,总结了一下 /** * Created by zhangqie on 2019/2/26 * Describe: 系统工具类 */ public class Equ ...

  9. Android获取cpu和内存信息、网址的代码

      android获取手机cpu并判断是单核还是多核 /** * Gets the number of cores available in this device, across all proce ...

  10. 【Android 应用开发】Android屏幕适配解析 - 详解像素,设备独立像素,归一化密度,精确密度及各种资源对应的尺寸密度分辨率适配问题

    . 作者 :万境绝尘 转载请注明出处 : http://blog.csdn.net/shulianghan/article/details/19698511 . 最近遇到了一系列的屏幕适配问题, 以及 ...

随机推荐

  1. centos离线安装mongodb-database-tools

    mongodb-database-tools是MongoDB数据库工具的命令行的工具,用于工作与MongoDB部署.可以使用mongodump和mongoimport很方便的导入导出备份数据. 该数据 ...

  2. CentOS7下的防火墙配置整理

    CentOS7下的防火墙配置整理 一.firewalld的基本使用 [root@localhost jack]# systemctl start firewalld # 启动防火墙 [root@loc ...

  3. 【可观测性系列】 Opentelemetry 介绍

    作者简介:大家好,我是蓝胖子 ️博客首页:博客园主页蓝胖子的编程梦 每日一句:人生的烦恼,多在于明白的太多,而做的太少 大家好,我是蓝胖子,随着微服务的流行,服务的可观测性概念被越来越多人提及到,究竟 ...

  4. docker之redis集群部署

    docker之redis集群部署 PART01: 3主3从redis集群部署 3主3从redis集群配置 关闭防火墙,启动docker服务 如果报以下错误,应该是docker 服务没有启动,可以执行下 ...

  5. postman application/json;

    看来以后需要都统一使用这个json比较方便. 首先看下 spring boot 项目接口的返回: 当然若不加,他默认可能也是 UTF-8,还是加一下吧.这样就可以了,保证以后 请求和响应的 conte ...

  6. CentOS7.5上Oracle19c离线rpm安装

    CentOS7.5上Oracle19c离线rpm安装 一.基础环境配置及依赖安装(1)关闭系统防火墙(如外网环境不能关闭防火墙自行开放相关需要使用的端口即可) systemctl stop firew ...

  7. 文心一言 VS 讯飞星火 VS chatgpt (197)-- 算法导论14.3 5题

    五.用go语言,对区间树 T 和一个区间 i ,请修改有关区间树的过程来支持新的操作 INTERVALSEARCH-EXACTLY(T,i) ,它返回一个指向 T 中结点 x 的指针,使得 x.int ...

  8. react router component与render有什么区别?提升渲染性能,记一个react router component 误用导致请求死循环的有趣bug

    壹 ❀ 引 下午前端大佬突然私聊我,说发现了一个很有趣的bug,问我有没有兴趣,因为我平时会记录一些自认为有意思的问题,所以毫不犹豫就答应了,问题表现如下,当我们系统进入到某个页面下时,接口居然无止境 ...

  9. Java Socket编程系列(二)开发带回声功能的Server和Client

    服务器端: package com.dylan.socket; import java.io.*; import java.net.ServerSocket; import java.net.Sock ...

  10. Java集合框架学习(十五) ListIterator接口详解

    ListIterator介绍 一个为list对象设计的迭代器,允许开发人员在2个方向上迭代,修改和获得list迭代位置. ListIterator 没有所谓当前元素. 它的游标位置总是位于previo ...