我有一个运行在我公司2000多台电脑的软件,没有任何问题。
此软件有时使用UuidCreateSequential()
( MSDN链接 )生成一个GUID
(或UUID
)。
该调用通常在每台计算机上返回RPC_S_OK
。 但是在其中之一,它总是返回RPC_S_UUID_LOCAL_ONLY
。
该文件指出:
当原始计算机没有以太网/令牌环(IEEE 802.x)地址时,UuidCreateSequential函数返回RPC_S_UUID_LOCAL_ONLY。
但是,这台电脑似乎没有networking问题。 它有一个既有效又唯一的MAC地址和IP地址的网卡,并且工作正常。
还有什么可能导致UuidCreateSequential()
总是返回RPC_S_UUID_LOCAL_ONLY
? 你有没有经历过类似的情况?
我可以帮助,有问题的电脑运行一个更新的Windows XP,与Service Pack 3。
我联系了微软,似乎这个错误只发生在Windows XP上,当MAC地址的第一个字节高于或等于0x80
。
Windows Vista和Windows 7已经修复了这个问题。 它不会被修复的Windows XP。
这是Windows XP和Windows server 2003中的一个错误。
MAC地址是48位,通常表示为:
00-01-02-0A-0B-0C 00:01:02:0a:0b:0c
前三个字节代表一个Organziation ,其余三个字节是组织要使用的任何编号方案。 组织ID是由IEEE颁发的。
对于所有公共MAC地址,第一个字节的第二低位(第二低位位)将为零。 如果您想要生成您自己的本地 MAC地址,您可以将该位设置为1:
00-01-02-0A-0B-0C 00000000-00000001-00000010-00001010-00001011-00001100 ^ | +- 0: Universal 1: Locally Administered
或从维基百科解除的图像:
Windows XP和Windows server 2003中的错误是他们正在检查错误的位。 他们错误地检查了高位 :
我讨厌把雷蒙德放在公共汽车下面,但这是一个不正确信息的例子 :
最后48位是计算机网卡的唯一地址。 如果计算机没有网卡,则设置最高位,并使用随机数发生器作为另一个47位。没有有效的网卡在其地址中设置最高位 ,因此不可能从一个生成的GUID没有网卡的计算机将意外地与从具有网卡的计算机生成的GUID冲突。
强调我的。 更正是说:
…设置第二个最低有效位…没有有效的网卡将设置第二个最低有效位。
我在我的电脑上测试了这个。 我的电脑有一个MAC地址:
C8-60-00-12-34-56 (Ok, i changed the serialized number, but it is a Realtek)
如果我们遵循Windows XP规则,这个MAC地址将被“本地管理” ,并且UuidCreateSequential将返回RPC_S_UUID_LOCAL_ONLY
当我在Windows 7上运行UuidCreateSequential
时,它运行正常:
{FBE65AFC-2588-11E5-9F09-C86000123456} {FBE65AFD-2588-11E5-9F09-C86000123456} {FBE65AFE-2588-11E5-9F09-C86000123456} {FBE65AFF-2588-11E5-9F09-C86000123456}
但是,如果我运行它在Windows XP机器上具有相同(或类似)的MAC地址:
该功能失败:
0x720仅在此计算机上有效的UUID已被分配。
检查MAC地址的错误位的错误记录在:
KB2569646:UuidCreateSequential API可能会返回RPC_S_UUID_LOCAL_ONLY(1824)错误。
发生此问题是因为如果MAC地址的第一位是ON(1)UuidCreateSequential API错误地将MAC地址识别为无效地址。
在UuidCreateSequential
中也记录了这一点:
KB981080:在具有有效网络适配器地址的计算机上使用UUIDGEN.exe命令或UuidCreateSequential函数时收到警告 :
出现此问题的原因是操作系统错误地评估网络适配器的MAC地址。
有一个相关的修复程序,但我不相信它是固定的(即没有在服务包中的正式修复)。
你有三个选择:
dwMajor < 6
)之前,则假定它实际上已成功( 危险! 也许这是一个安全问题,是用户打电话给管理员? 否则,NIC驱动程序可能无法提供MAC地址。
只要UUID用于该机器的本地,那么接受这个错误作为一个有效的结果可能是好的。
如果UUID必须保证全球唯一(例如资产注册),那么询问另一个框(例如注册服务器)可能是更好的主意。