关于获取设备的唯一设备ID,MAC地址 IOS/Android问题

Hi,大家好。
关于账号快速登录问题的解决方案。区分ios和Android,此时要获取机器的udid。 
Android下很快解决了,调用几个系统API,网上解决办法一堆。总体来说Android下udid为IMEI+Mac地址,也就是这两个数据拼成的串。
而在ios5.0以后,官方为了保护用户隐私,删除了获取设备udid的接口,虽然代码还在,但是获取出来的数据已经不对。官方在ios7.0以后提供了一个获取udid的快速办法。 代码如下:
CFUUIDRef uuidRef = CFUUIDCreate(kCFAllocatorDefault);
          NSString *uuid  = (NSString *)CFUUIDCreateString  (kCFAllocatorDefault,uuidRef);
然后官方的建议是把当前的udid储存到app本地,这时问题来了。当用户把app卸载之后,这个udid已经随着包的消失而消失了,这时就需要我们来解决这个udid储存的问题。网上找了各种解决办法,最后差不多半天时间找到了解决办法并解决了。OS X和IOS都有一个钥匙串的概念,ios的相比OS X简单。我们即需把这个udid储存到IOS的钥匙串里。
具体的内容还需谢谢下面这个链接的作者: 点击打开链接
注:具体的设置group组信息的时候根据XCode版本不同可能方式不同。
即使IOS设备越狱后,该udid还是会在钥匙串中,数据存在。亲测。大家请放心。
开始写博客了,以后会在此处更新一些技术方面的文章。该篇文章算是一个总结,该内容是在之前做过的,可能感觉大家也遇到过该类问题。
如果有不懂的,可以联系我。可以提供内容讲解以及操作。
### 获取唯一设备ID的挑战 在开发过程中,获取一个能够唯一标识设备ID是一个常见的需求。然而,在AndroidiOS平台上,由于隐私政策和技术限制的影响,这一目标变得愈发困难。 #### Android 平台上的解决方案 在Android平台上,虽然存在多种可能用于识别设备的方式,但由于系统更新以及对用户隐私保护的要求日益严格,许多传统方法已经不再适用[^1]。例如,IMEI、MAC地址Android ID曾被广泛使用,但这些方式要么受到权限限制,要么无法满足跨应用的一致性和稳定性要求[^2]。 一种推荐的做法是创建并存储自定义的应用级UUID作为设备标识符。这种方法可以确保即使操作系统版本发生变化或者硬件特性不可访问的情况下仍然有效: ```java public class DeviceIdManager { private static final String PREFS_FILE = "device_id.xml"; private static final String PREFS_DEVICE_ID = "device_id"; public static String getDeviceId(Context context) { SharedPreferences prefs = context.getSharedPreferences(PREFS_FILE, Context.MODE_PRIVATE); String deviceId = prefs.getString(PREFS_DEVICE_ID, null); if (deviceId == null) { deviceId = UUID.randomUUID().toString(); SharedPreferences.Editor editor = prefs.edit(); editor.putString(PREFS_DEVICE_ID, deviceId); editor.apply(); } return deviceId; } } ``` 此代码片段展示了如何利用SharedPreferences保存一个随机生成的UUID,并将其作为设备ID返回。 #### iOS 平台上的解决方案 对于iOS来说,苹果公司出于隐私考虑早已停止支持UDID等可以直接追踪用户的标识方案。目前官方建议使用的Identifier For Vendor(IDFV),它由App Store分配给同一供应商下的所有应用程序共享同一个值直到卸载最后一个关联程序为止;还有Advertising Identifier(IDFA),主要用于广告目的且允许用户重置或禁用其跟踪功能。 如果需要更持久可靠的解决办法,则可以通过Keychain服务来储存自行产生的GUID形式的数据串当作专属标志码: ```swift import UIKit import Security func save(key: String, data: Data) -> OSStatus { let query: [String : Any] = [ kSecClass as String : kSecClassGenericPassword, kSecAttrAccount as String : key, kSecValueData as String : data ] SecItemDelete(query as CFDictionary) return SecItemAdd(query as CFDictionary, nil) } func load(key: String) -> Data? { let query: [String : Any] = [ kSecClass as String : kSecClassGenericPassword, kSecAttrAccount as String : key, kSecReturnData as String : true, kSecMatchLimit as String : kSecMatchLimitOne ] var result: AnyObject? SecItemCopyMatching(query as CFDictionary, &result) return result as? Data } let deviceIDKey = "com.example.deviceid" if let storedData = load(key: deviceIDKey), let id = NSString(data:storedData, encoding:String.Encoding.utf8.rawValue){ print(id) } else{ let newID = NSUUID().uuidString.data(using:.utf8)! _ = save(key: deviceIDKey, data:newID) print(String(data:newID,encoding:.utf8)!) } ``` 上述Swift代码实现了基于Keychain的安全数据存取机制,从而达到长期保留特定字符串的目的。 ### 结论 综上所述,在当前环境下无论是Android还是iOS都无法简单直接地获得完全意义上的永久型物理装置编号。因此采用软件层面构建逻辑实体号成为主流趋势之一。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

WhiteTian

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值