请选择 进入手机版 | 继续访问电脑版

扫一扫,访问微社区

查看: 1549|回复: 3

移动端设备ID标识整理|获取IMEI、MEID、ICCID

  [复制链接]

6

主题

6

帖子

34

积分

版主

Rank: 7Rank: 7Rank: 7

积分
34
发表于 2019-1-23 09:30:27 | 显示全部楼层 |阅读模式
本帖最后由 艾威氪网络科技 于 2019-1-23 09:32 编辑

移动设备ID信息在移动端产品的开发中,如何定位一台设备,定位一个人,是一个棘手的问题,在适配的过程中也会遇到千奇百怪的情况。本文介绍了常用的设备ID以及标识设备的方法与一些常见问题。
移动设备ID可分为三部分:硬件层面,系统层面,软件层面。


系统区别由于IOS系统限制问题,在IOS上可获取的设备ID为IDFV、IDFA,其他设备ID需要越狱手机才可获取。
而在Android系统中,通常使用IMEI、MAC去标识一台设备。但除了这几个ID之外,还有MEID、SN码、ANDROID_ID、IMSI、ICCID等ID,各自有着自己的用途。


Android系统相关ID信息以下是一个Android手机正常可获取到的ID信息


Android系统ID

下面逐个介绍这些ID以及用途

硬件层面硬件层面的ID标识一般用于跨应用获取设备信息,主要有:标识设备的IMEI、MEID、MAC(网卡)及标识SIM卡的IMSI、ICCID。
硬件信息烧制在硬件之中,属于底层信息,不可更改。但可以通过修改系统调用API达到修改获取的目的。



IMEI、MEID简介IMEI、MEID都是用于标识一台物理设备的ID信息。在Android 8.0以下系统提供的API中,会根据不同条件返回二者之一的信息。
  • IMEI: 国际移动设备识别码,是区别移动设备的标志,一般用于标识某一台独立的设备,双卡双待的手机有两个IMEI号。
    格式:15位十进制数
  • MEID: 同样也是移动设备标识码,但一般用于CDMA制式的设备上,是ESN码的升级版。
    格式:14位十六进制数



权限获取时,二者均需要开启权限:READ_PHONE_STATE。
在Android 6.0以上的版本中,若需要获取该权限的内容,第一次启动时系统会给出弹窗提示: XXX需要使用电话权限...

权限弹框


APIAndroid 8.0以上的系统,TelephonyManager提供了两个独立的API以获取IMEI和MEID: getImei 、 getMeid 。两个API都可传入下标号获取多个设备号信息(截止今天8.0以上版本约占市场份额的6%)。
Android 8.0以下的系统获取IMEI或MEID的API为TelephonyManager.getDeviceId(),若当前设备有MEID号,则优先返回MEID,否则返回IMEI号。则获取到的设备ID需要通过长度判断才能知晓该ID为IMEI还是MEID,会存在IMEI获取不到,只能获取MEID的情况。

  • Android 6.0以下的系统,即使是双卡双待的设备,也只能获取一个DeviceId。
    :getDeviceId在某些特别旧版本的设备中会返回ESN码,此情况在文中忽略。
  • Android 6.0以上的系统,使用getDeviceId可传入下标号获取多个设备号信息。
    双卡双待手机出现以下情况:(以华为Mate 10为例)

[td]
卡1卡2getDeviceId(0)getDeviceId(1)
无/非电信卡无/非电信卡IMEIIMEI
电信卡无/非电信卡MEIDIMEI
通常一台手机不会携带两张电信卡,则通常情况下一台手机只有一个MEID

MAC简介
MAC:硬件地址,通过获取网卡的MAC地址,一般与IMEI一起使用定位一台设备
格式:48bit(6字节)加上分隔符的字符串


权限及APIMAC:需要开启权限INTERNET、ACCESS_WIFI_STATE、ACCESS_NETWORK_STATE,用户在安装APP时会提示需要此类权限。
获取方法根据不同版本有不同的获取方法,具体方法可参考网上提供的方法,不在这里赘述。


IMSI、ICCID简介IMSI、ICCID标识的是SIM卡的信息。 若当前用户更换了手机,仍可通过SIM卡的信息跟踪该用户。
  • IMSI:国际移动用户识别码,是区别移动用户的标识,储存在SIM卡中,可用于区别移动用户的有效信息,通过IMSI可反查运营商、归属地、手机号码等信息,在接入网络时会到运营商服务器中进行验证。
    格式:15位0-9的数字
  • ICCID:SIM卡卡号,是卡的标识,不作接入网络的鉴权认证,可在SIM卡卡后查询到。
    格式:大多为19或20位0-9的数字,亦存在6位/12位的情况



权限及API二者需要的权限与IMEI一致:READ_PHONE_STATE,调用的API为:
IMSI:TelephonyManager.getSubscriberId()
ICCID:TelephonyManager.getSimSerialNumber()
由于API并没有随着Android版本的更新而更新过,对于双卡双待的设备而言,只会返回一个卡的ID信息。

[td]
卡1卡2getSubscriberId()getSimSerialNumber()
有卡无卡卡1 IMSI卡1 ICCID
无卡有卡卡2 IMSI卡2 ICCID
有卡有卡卡1 IMSI卡1 ICCID


更改硬件层面的ID信息获取在Android系统中,可以通过Xposed框架(需要root)对系统级别的API进行拦截、修改,从而改变硬件层面的ID信息的获取。此类方法也适用于其他ID的修改。
Xposed框架需要root权限进行API拦截,也存在免root的拦截工具,但只能针对某一个应用进行拦截。



系统层面系统层面的ID亦可用于跨应用获取信息,但其中的某些ID会随着系统的改变而改变。
在Android系统中,代表是SN、ANDROID_ID、GAID,在IOS系统中,代表是IDFA、IDFV


SN、ANDROID_ID、GAID简介
  • SN:设备序列号,Serial Number的缩写。SN码是为了验证产品合法而存在的,也称作机器码、认证码、注册码。可使用adb调试工具中使用adb devices查看到,亦可在系统信息中的序列号一栏看到,一般不可更改。
    格式:生产厂商自定义,山寨机中存在重复的情况
  • ANDROID_ID:设备首次启动随机生成的ID,设备还原出厂设置后会重新生成  
    格式:长度为16位的字符串,但由于生产厂商定制系统的Bug,有的设备会生成相同的ID,或者返回null
  • GAID:由Google Play Service提供,需要安装Google Play的SDK或者设备本身有Google Play才可使用,由于国内环境特殊,此ID不可用,不再展开。


权限及API
  • SN:Android 8.1以下版本中不需要特殊的权限,通过获取Build.SERIAL的值即可。
    但在Android 8.1以上的版本中,需要READ_PHONE_STATE权限,通过Build.getSerial()进行获取。
    则:主流品牌的设备可以使用品牌+SN码进行设备标识。
  • ANDROID_ID:无需权限即可获取,调用:
    Settings.Secure.getString(this.getContentResolver(), Settings.Secure.ANDROID_ID)  
    或  Settings.System.getString(this.getContentResolver(), Settings.System.ANDROID_ID)  
    即可。
    通过adb工具可以获取、修改ANDROID_ID:
    1. #获取
    2. adb shell content query --uri content://settings/secure --where "name=\'android_id\'"
    3. #删除
    4. adb shell content delete --uri content://settings/secure --where "name=\'android_id\'"
    5. #重新插入
    6. adb shell content insert --uri content://settings/secure --bind name:s:android_id --bind value:s:<new_id>
    复制代码



IDFV、IDFA
  • 注:由于本人非IOS开发人员,以下资料仅供参考

简介

    • IDFV:IOS提供的应用商级别的用户标识符。
      若一台设备安装了两款由同一个应用商开发的APP,则这两个APP获取到的IDFV一致。例如:对于com.testcompany.browser以及com.testcompany.qq两个应用,由于同属一个应用商testcompany,则可以获取到同一个IDFV来标识用户。
      例子:95955F33-BFBD-48BA-A630-866D2DAE482D
    • IDFA:IOS提供的广告标示符,如果用户重置系统或选择还原广告标示符,该ID会重新生成。
      例子:9C287922-EE26-4501-94B5-DDE6F83E1475


IDFA扩展
  • 由于IDFA受广告限制跟踪开关的影响,可用SimulateIDFA以及OpenIDFA解决这一问题,但在稳定性上有一定的偏差。
    二者都是根据手机的设备信息生成的一个MD5值,从而达到同一设备不同APP获取到的值都一样的目的。
    利用的设备信息包括:设备名称、系统coreServices文件创建及更新时间、系统版本、系统容量等信息。有的会随着系统的升级而改变,准确度不高,需要做兼容性处理。




软件层面
  • 软件层面的ID在用户跟踪方面就显得十分弱势了:
UUID
  • 通用唯一标识码,是用于软件开发的ID格式标准。通常软件自身生成以UUID为格式的ID来进行软件内部的用户标记。
    Android系统可直接调用APIUUID.randomUUID()生成。
    IOS系统可以通过系统自带的KeyChain进行UUID的持久保存,若当前APP被删除,再安装仍可以拿到这个ID信息。
    格式:由4个连字号(-)将32个字节长的字符串分隔后生成的字符串,总共36个字节长
    例子:550e8400-e29b-41d4-a716-446655440000

第三方服务OpenID
  • Android环境下,存在一些后台常驻的第三方服务,如推送服务(推啊、友盟、小米推送等)。可以接入此类第三方服务达到跨应用标识设备的目的。












上一篇:android获取手机IMSI号
下一篇:获取Android设备唯一标识码
回复

使用道具 举报

0

主题

0

帖子

2

积分

新手上路

Rank: 1

积分
2
发表于 2019-9-3 08:19:39 | 显示全部楼层
看后感悟了点,收下了












武穴论坛
武穴社区
武穴贴吧
武穴风云网
回复

使用道具 举报

0

主题

0

帖子

2

积分

新手上路

Rank: 1

积分
2
发表于 2020-1-13 16:09:38 | 显示全部楼层
回复

使用道具 举报

0

主题

25

帖子

154

积分

注册会员

Rank: 2

积分
154
发表于 2020-7-11 21:10:30 | 显示全部楼层

【环球网综合报道】三面观音香港知专设计学院15岁女生陈彦霖于9月死亡,后被警方证实为。但一些人借此炒作,宣称其死于警方“谋杀”。据香港无线电视(TVB)17日报道,陈彦霖母亲首次公开表态称,表示相信女儿是身亡,希望谣言尽快停止,还她及死去的女儿宁静。





陈彦霖母亲接受港媒专访(港媒截图)


据港媒此前报道,陈彦霖9月22日被人发现溺亡,校方曾发布视频,显示陈在事发前独自离校,没鱼篮观音被陌生人挟持。香港警方也在11日澄清,陈彦霖死因是,没有可疑迹象。警察公共关系科署理总警司江楞严经永祥在11日警方记者会上表示,经检查,陈的身体上并无表面伤痕或性侵迹象。


不过激进分子连续数十天以来不停拿此案进行炒作,声称其死亡与所谓的“便衣警察”有关,甚至还有暴徒借此案到陈的学校搞事。为澄清谣言,陈彦霖母亲何女士于17日接受TVB专访,谈及女儿的事件。


为免受怀疑,何女士主动展示女儿陈彦霖的出生证明及多张合照,并主动解释受访原因。她表示,自己一直与警方跟进事件,看过所有闭路电视片段,察觉到 女儿出事前已有神情异常的情况。她说,女儿8月起曾对她不止一次表示她洒水观音出现幻听,何怀疑女儿受“思觉失调”(精神分裂)困扰。


何女士又金刚萨埵回忆表示,女儿曾说不想再上街,因为“整件事已经变了质”,而女儿误中催泪弹一事更与网传谣言完全不符。她说女儿当时只是去购物,不料受到波及。对女儿死因,她起初也曾有怀疑过,但后来她自己身份被人在网上“起底”,让她明白部分人并非关心她的女儿,事件演变成对她的滋扰。


何女士最后表示,“不需要你们去为她‘沉冤得雪’,我们一家人已经够惨,已经失去了我们最爱的女儿,不要再推测,不要胡乱去讲任何你们认为的事,我只想他们(造谣者)放过我们一家人。我想我的女儿安息,以前她最怕人烦最怕人吵,你们天天在吵,很困扰,我相信她在天之灵也觉得困扰。”


送子观音了骚扰陈彦霖母亲,香港部分激进分子还曾滋扰陈彦霖生前所在的学校。据香港《大公报》16日报道,黑衣暴徒近日连续两天以陈彦霖死亡案为由,破龙头观音坏香港知专设计学院,教室及图书馆的玻璃被损毁,更有一批身穿黑衣的学生在地下设所谓“祭台”,撒“纸钱”。





暴徒近日连续破坏香港知专设计学院(图片来源:香港《大公报》)


其中,15日约有20名黑衣暴徒再校园,闯入图书馆、学习资源中心等地,打烂玻璃及部分电脑,墙上喷写“交出完整CCTV(视频录像)”、“学校隐瞒”等字句,还有人拉出消防栓向电梯灌水,再到不同楼层破坏房门玻璃、课室拍卡机。学校15日起停课三天,仍未确定18日能否复课。


在这种情况下,网上圆光观音16日就已经出现了自称陈彦霖母亲何女士所发的文章,其在文章中痛斥:“实在受够了!请你们停手!”这篇文章题为《请保护我女儿私隐及还我们一个宁静》。文中提到,自己和家人决定火化女儿遗体,因为想她女儿早日入土为安,“请大家不要作无谓揣测”。


她希望校方不要因为所谓“持强烈政见人士”要求,而公开和她女儿相关的闭路电视片段。“我想问大家:我女儿已经死去,是否连她的一点私隐,都不可以保留?我女儿从来没有因为近日事件而被捕,请不要玷污她的名声。”


她透露,自己手机不断受到滋扰,甚游戏观音至平日工作也饱受持强烈政见人士滋扰。她恳请大家放过她和家人,“我已经失去了一个我十分疼爱的女儿楞严经,我不想连我和家人的宁静的生活也失去。”她恳求还她和家人一个安宁,让死者可以安息,让执法机关去处理。她最后在信中表示,希望香港早日回复宁静。




回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

快速回复 返回顶部 返回列表