在支持android系统升级上,哪个手机厂商比较好

在支持android系统升级上,哪个手机厂商比较好,第1张

这个问题比较宽泛。

既然android是Google自家孩子,当时是自家孩子最亲了,每一次Google发布新版本,都是从自家机器先开始,其实Google的案桌机还是很不错的,比如Nexus One 和 Nexus S。但是android系统是一个广泛开源的系统,其他大有名气的厂家也很多。目前来看机型最多的就应该是HTC了,从 G1到 G9(G5除外),Desire、Desire HD,wildfire等等,不论从性能还是外观上看,HTC都是相当不错。

还有不得不说的两家就是摩托罗拉和三星,摩托罗拉借助里程碑成功撅起之后,也有诸多经典机型问世,比如里程碑2,胭脂盒,以及三防机defy等等。但是由于种种原因,摩托的机器升级总是缓慢,当年的里程碑如今也已经黯然失色了,但是摩托罗拉细腻的做工,商务化的气质仍然是让很多人不能割舍的。三星的旗舰android机当属i9000,从机器配置上来说这绝对是一款剽悍的机器,外观上看个人感觉一般但是三星凭借在中国手机用户中的良好销量和口碑,还是占有一席之地的。

此外还有LG,索尼爱立信等等厂商,但是因为机型不多或者中国上市不多,份额较小。

在这里不得不说的是国产的许多机器,也是相当不错,比如中兴,华为。联想乐phone也很不错,已经升级至22。 其实最应该说说的就是魅族了,号称挑战iphone的魅族m9,从机器外观,配置等等方面看都很不错,拥有960x640超高分辨率,所谓的国产神机。但是从m9上市以来消费者反馈的情况看,m9似乎存在很多问题,还要看时间的考验啊~ 具体哪款机型要看楼主的个人需要了~

本人目前用摩托罗拉里程碑~

android其实是基于linux的一个 *** 作系统,只是被用到了移动设备上面了,如果你想在pc上面安装android系统,理论上是完全可行的。

现在其实才牵涉到了android root的原理,root其实就是获取android系统的root权限。至于原理:手机制造商原始出厂的手机并未开放root权限,获取root的方法都是不受官方支持的,因此,目前获取root的方法都是利用系统漏洞实现的。而不同手机厂商可能存在的漏洞不同,也就导致了不同手机root的原理可能不同。不过,不管采用什么原理实现root,最终都需要将su可执行文件复制到Android系统的/system分区下(例如:/system/xbin/su) 并用chmod命令为其设置可执行权限和setuid权限。为了让用户可以控制root权限的使用,防止其被未经授权的应用所调用,通常还有一个Android应用程序来管理su程序的行为。root的基本原理就是利用系统漏洞,将su和对应的Android管理应用复制到/system分区。(这个是我复制的维基百科的,如果你懂一点儿linux,那么这个过程就很好理解,如果不懂呢,那么你可以忽略掉。)

有很多场景和需求你需要用到手机设备的唯一标识符。例如,略。

在Android中,有以下几种方法获取这样的ID。

1 The IMEI: 仅仅只对Android手机有效:

TelephonyManager TelephonyMgr = (TelephonyManager)getSystemService(TELEPHONY_SERVICE);

String szImei = TelephonyMgrgetDeviceId(); // Requires READ_PHONE_STATE

采用此种方法,需要在AndroidManifestxml中加入一个许可:androidpermissionREAD_PHONE_STATE,并且用户应当允许安装此应用。作为手机来讲,IMEI是唯一的,它应该类似于 359881030314356(除非你有一个没有量产的手机(水货)它可能有无效的IMEI,如:0000000000000)。

2 Pseudo-Unique ID, 这个在任何Android手机中都有效

有一些特殊的情况,一些如平板电脑的设置没有通话功能,或者你不愿加入READ_PHONE_STATE许可。而你仍然想获得唯一序列号之类的东西。这时你可以通过取出ROM版本、制造商、CPU型号、以及其他硬件信息来实现这一点。这样计算出来的ID不是唯一的(因为如果两个手机应用了同样的硬件以及Rom 镜像)。但应当明白的是,出现类似情况的可能性基本可以忽略。要实现这一点,你可以使用Build类:

String m_szDevIDShort = "35" + //we make this look like a valid IMEI

BuildBOARDlength()%10+ BuildBRANDlength()%10 + BuildCPU_ABIlength()%10 + BuildDEVICElength()%10 + BuildDISPLAYlength()%10 + BuildHOSTlength()%10 + BuildIDlength()%10 + BuildMANUFACTURERlength()%10 + BuildMODELlength()%10 + BuildPRODUCTlength()%10 + BuildTAGSlength()%10 + BuildTYPElength()%10 + BuildUSERlength()%10 ; //13 digits

大多数的Build成员都是字符串形式的,我们只取他们的长度信息。我们取到13个数字,并在前面加上“35”。这样这个ID看起来就和15位IMEI一样了。

3 The Android ID , 通常被认为不可信,因为它有时为null。开发文档中说明了:这个ID会改变如果进行了出厂设置。并且,如果某个Andorid手机被Root过的话,这个ID也可以被任意改变。

String m_szAndroidID = SecuregetString(getContentResolver(), SecureANDROID_ID);

Returns: 9774d56d682e549c 无需任何许可。

4 The WLAN MAC Address string, 是另一个唯一ID。但是你需要为你的工程加入androidpermissionACCESS_WIFI_STATE 权限,否则这个地址会为null。

WifiManager wm = (WifiManager)getSystemService(ContextWIFI_SERVICE);

String m_szWLANMAC = wmgetConnectionInfo()getMacAddress();

Returns: 00:11:22:33:44:55 (这不是一个真实的地址。而且这个地址能轻易地被伪造。)WLan不必打开,就可读取些值。

5 The BT MAC Address string, 只在有蓝牙的设备上运行。并且要加入androidpermissionBLUETOOTH 权限

BluetoothAdapter m_BluetoothAdapter = null; // Local Bluetooth adapter

m_BluetoothAdapter = BluetoothAdaptergetDefaultAdapter();

String m_szBTMAC = m_BluetoothAdaptergetAddress();

Returns: 43:25:78:50:93:38 蓝牙没有必要打开,也能读取。

Combined Device ID

综上所述,我们一共有五种方式取得设备的唯一标识。它们中的一些可能会返回null,或者由于硬件缺失、权限问题等获取失败。

但你总能获得至少一个能用。所以,最好的方法就是通过拼接,或者拼接后的计算出的MD5值来产生一个结果。

String m_szLongID = m_szImei + m_szDevIDShort

+ m_szAndroidID+ m_szWLANMAC + m_szBTMAC;

// compute md5

MessageDigest m = null;

try {

m = MessageDigestgetInstance("MD5");

} catch (NoSuchAlgorithmException e) {

eprintStackTrace();

}

mupdate(m_szLongIDgetBytes(),0,m_szLongIDlength());

// get md5 bytes

byte p_md5Data[] = mdigest();

// create a hex string

String m_szUniqueID = new String();

for (int i=0;i<p_md5Datalength;i++) {

int b = (0xFF & p_md5Data[i]);

// if it is a single digit, make sure it have 0 in front (proper padding)

if (b <= 0xF)

m_szUniqueID+="0";

// add number to string

m_szUniqueID+=IntegertoHexString(b);

} // hex string to uppercase

m_szUniqueID = m_szUniqueIDtoUpperCase();

通过以上算法,可产生32位的16进制数据:

9DDDF85AFF0A87974CE4541BD94D5F55

现在你就可以对其进行你的应用了。

TelephonyManager tel = (TelephonyManager) paramContextgetSystemService(ContextTELEPHONY_SERVICE);CellLocation cellLocation = telgetCellLocation(); int nPhoneType = telgetPhoneType(); if (nPhoneType == 1 && cellLocation instanceof GsmCellLocation) { thisisGsm = true; GsmCellLocation gsmCellLocation = (GsmCellLocation) cellLocation; int nGSMCID = gsmCellLocationgetCid(); if (nGSMCID > 0) { if (nGSMCID != 65535) { thiscid = nGSMCID; thislac = gsmCellLocationgetLac(); } } }

这个是context类里的方法,如果你是在activity里写的代码,因为activity继承自context类,所以不用在传context对象,可以直接用,要是在其他类里,就要穿入context对象了,而且这个方法需要权限的,要在清单文件中声明权限

以上就是关于在支持android系统升级上,哪个手机厂商比较好全部的内容,包括:在支持android系统升级上,哪个手机厂商比较好、Android 的提权 (Root) 原理是什么、如何获取Android唯一标识等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!

欢迎分享,转载请注明来源:内存溢出

原文地址:https://54852.com/web/10158876.html

(0)
打赏 微信扫一扫微信扫一扫 支付宝扫一扫支付宝扫一扫
上一篇 2023-05-05
下一篇2023-05-05

发表评论

登录后才能评论

评论列表(0条)

    保存