我一直在使用WifiInfo.getMacAddress
我的 nexus 一个或我能够使用的任何其他移动设备上看到的字符串,即格式为01:02:03:04:05:06
但是我的应用程序的一个用户刚刚报告了一个崩溃Toshiba Folio100
,我的 MAC 地址解析失败。由于我没有任何日志文件并且报告是匿名的,我无法联系那个人,所以我在这里问你是否知道它是如何在这种设备中编码的。
我想可能是这样010203040506
,但我没有那么自信。
我一直在使用WifiInfo.getMacAddress
我的 nexus 一个或我能够使用的任何其他移动设备上看到的字符串,即格式为01:02:03:04:05:06
但是我的应用程序的一个用户刚刚报告了一个崩溃Toshiba Folio100
,我的 MAC 地址解析失败。由于我没有任何日志文件并且报告是匿名的,我无法联系那个人,所以我在这里问你是否知道它是如何在这种设备中编码的。
我想可能是这样010203040506
,但我没有那么自信。
虽然我不能具体评论东芝对开本,但我会敦促您重新考虑如何解析 MAC 地址字符串。
多年前我编写了代码来从 PC 中的 NIC 获取 MAC 地址 - 因为它使用卡的 PC 驱动程序,格式可能因制造商而异。WifiInfo.getMACAddress() 的文档实际上并没有保证如何返回此字符串,因此请考虑为所有可能发生的情况做准备。
我看到了以下格式...
01:02:03:04:05:06 // Delimited with ':' and padded to 2 chars
1:2:3:4:5:6 // Delimited but if < 16, there was no leading '0'
010203040506 // No delimiters but octets ALWAYS pre-padded with '0' when < 16
注意:字母字符也可能是大写或小写(尽管在每种情况下都是一致的,即全部大写或全部小写)。例子...
0A0B0C0D0E0F
0a0b0c0d0e0f
A:B:C:D:E:F
a:b:c:d:e:f
为了应对上述情况,我首先强制字符串 toLower()。
然后我检查了':'的存在。如果它存在,我会将字符串拆分为一个数组,然后检查数组中每个“八位字节字符串”的长度,如果长度 = 1,则不使用填充,所以我会添加前缀“0”。最后,我将通过使用 ':' 作为分隔符连接每个数组元素来重新组合字符串。
如果字符串不包含':',那么我会确认它的长度= 12,此时我将使用每对字符重建字符串并用':'分隔。
如果字符串没有分隔并且它的长度不是 12,那么就不可能正确解析,我不得不假设请求 MAC 地址字符串失败并且我报告了错误的 MAC 地址。