在Android应用程序中,如何在系统设置 - >中显示主机设备的内部版本号。关于平板电脑 - >以编程方式获取Build Number 以便在Java Android应用程序中使用?
目前,我正在使用“android.os.Build”。
答案 0 :(得分:18)
检查此代码..
在Build.FINGERPRINT
中,您将获得设备的Build Number
。
String mString = "";
mString.concat("VERSION.RELEASE {" + Build.VERSION.RELEASE + "}");
mString.concat("\nVERSION.INCREMENTAL {" + Build.VERSION.INCREMENTAL + "}");
mString.concat("\nVERSION.SDK {" + Build.VERSION.SDK + "}");
mString.concat("\nBOARD {" + Build.BOARD + "}");
mString.concat("\nBRAND {" + Build.BRAND + "}");
mString.concat("\nDEVICE {" + Build.DEVICE + "}");
mString.concat("\nFINGERPRINT {" + Build.FINGERPRINT + "}");
mString.concat("\nHOST {" + Build.HOST + "}");
mString.concat("\nID {" + Build.ID + "}");
((TextView) findViewById(R.id.textView1)).setText(mString);
我的设备内部版本号:
FINGERPRINT
返回上述代码
答案 1 :(得分:4)
要获取此值,请使用Build.DISPLAY。以下是Verizon Note 2(Android 4.4.2上的SCH-I605)的示例: KOT49H.I605VRUFND7
要求:API 3或更高版本。
答案 2 :(得分:3)
我希望它返回你想要的相同值。
String build_number = Build.FINGERPRINT;
System.out.println("Build Number" + build_number);
答案 3 :(得分:3)
要仅获取设置中“关于设备”所示的内部版本号值,我们可以使用以下静态方法:
/**
* This method returns Build Number of the device from the OS Build fingerprint
* @return osBuildNumber - human entered name of the device
*/
public static String getOSBuildNumber() {
String osBuildNumber = Build.FINGERPRINT; //"google/shamu/shamu:5.1.1/LMY48Y/2364368:user/release-keys”
final String forwardSlash = "/";
String osReleaseVersion = Build.VERSION.RELEASE + forwardSlash;
try {
osBuildNumber = osBuildNumber.substring(osBuildNumber.indexOf(osReleaseVersion)); //"5.1.1/LMY48Y/2364368:user/release-keys”
osBuildNumber = osBuildNumber.replace(osReleaseVersion, ""); //"LMY48Y/2364368:user/release-keys”
osBuildNumber = osBuildNumber.substring(0, osBuildNumber.indexOf(forwardSlash)); //"LMY48Y"
} catch (Exception e) {
Log.e("getOSBuildNumber", "Exception while parsing - " + e.getMessage());
}
return osBuildNumber;
}
这将只返回内部版本号的确切值。请记住,Android SDK不会这样做。检查BUILD类中的以下代码段:
/** A string that uniquely identifies this build. Do not attempt to parse this value. */
public static final String FINGERPRINT = deriveFingerprint();
/**
* Some devices split the fingerprint components between multiple
* partitions, so we might derive the fingerprint at runtime.
*/
private static String deriveFingerprint() {
String finger = SystemProperties.get("ro.build.fingerprint");
if (TextUtils.isEmpty(finger)) {
finger = getString("ro.product.brand") + '/' +
getString("ro.product.name") + '/' +
getString("ro.product.device") + ':' +
getString("ro.build.version.release") + '/' +
getString("ro.build.id") + '/' +
getString("ro.build.version.incremental") + ':' +
getString("ro.build.type") + '/' +
getString("ro.build.tags");
}
return finger;
}
上述方法只是对“deriveFingerprint()”方法中提供的数据进行逆向工程。
答案 4 :(得分:1)
我使用String Build_Number = Build.DISPLAY;
来获取电话设置中显示的内部版本号
答案 5 :(得分:0)
将Build.DISPLAY用于内部版本号
答案 6 :(得分:0)
Log.i("TAG", "SERIAL: " + Build.SERIAL);
Log.i("TAG","MODEL: " + Build.MODEL);
Log.i("TAG","ID: " + Build.ID);
Log.i("TAG","Manufacture: " + Build.MANUFACTURER);
Log.i("TAG","brand: " + Build.BRAND);
Log.i("TAG","type: " + Build.TYPE);
Log.i("TAG","user: " + Build.USER);
Log.i("TAG","BASE: " + Build.VERSION_CODES.BASE);
Log.i("TAG","INCREMENTAL " + Build.VERSION.INCREMENTAL);
Log.i("TAG","SDK " + Build.VERSION.SDK);
Log.i("TAG","BOARD: " + Build.BOARD);
Log.i("TAG","BRAND " + Build.BRAND);
Log.i("TAG","HOST " + Build.HOST);
Log.i("TAG","FINGERPRINT: "+Build.FINGERPRINT);
Log.i("TAG","Version Code: " + Build.VERSION.RELEASE);
它会起作用。