Search code examples
iphoneudid

How can I make ios UDID shorter but still unique enlough


I want to make the UDID of a iOS device to less than or equal to 15 characters.

I am porting a Symbian based client-server software to iOS. The server side uses IMEI (15 digits)to id a client phone. Now on iOS, UDID is too long(40 hex digits). As I want to minimize the change of server program or DB, I need to store the UDID in a varchar(15).

So it's there any way to make the UDID shorter but still unique enlough. It could be much better if I can also get the UDID from the shorted string.


Solution

  • You could convert the hex digits into 20 Latin-1 characters (≤0xff) or 10 Unicode BMP characters (≤0xffff).

    If that varchar(15) can accept Unicode BMP characters, then we are done.

    Otherwise, you could chop the last 5 characters from that 20 Latin-1 characters. The UDID is in fact a SHA-1 hash of some device-unique values, which can be considered quite random and the digits are uniformly distributed. Therefore, with 15 Latin-1 characters the reduced UDID should be able to represent 25615 ~ 1036 devices, which is much more than enough.

    In fact, even if you just take 15 hex characters from the UDID it could already represent ~ 1018 devices.

    Note that the last 2 methods are lossy, i.e. there is no way you could get the complete UDID from the 15 characters.