十六进制到 int 和 back 给出不同的结果

问题描述

我得到一个 MAC 地址作为十六进制字符串“0009A8040060”,我想将最后 3 个字节转换为 int。然后我想把它隐藏起来。我以为我了解十六进制转换的基础知识 - 但显然不是!

到目前为止我的尝试是

string endSerial = "0009A8040060".Substring(6);
int key = Convert.ToInt32(endSerial,16);

键在 262240 之后。这似乎是正确的,但是当我使用服务器上运行的代码进行转换时(我无法更改)

int key = x; // receives over tcp. I´ve logged this int and its transferred ok!
string endSerial = BitConverter.ToString(BitConverter.GetBytes(Convert.ToUInt32(key))).Replace("-","");

这给出了 endSerial = 60000400

我希望它是 00040060。似乎有某种反向问题? BitConverter.IsLittleEndian 总是正确的。

请帮忙

解决方法

通常情况下,您不会使用 BitConverter,而是会这样做:

key.ToString("X6");

但是,显然您无法更改 BitConverter 代码,因此这不是一个选项。


正如您所发现的,

BitConveter 以小端字节序输出字节 - 最不重要的字节在前。但是,当您使用 Convert.ToInt32 转换字符串“040060”时,可以将其视为使用大端 - 第一个字节 04 被视为最高有效字节。这是因为 Convert.ToInt32 旨在解析以“日常生活”方式书写的数字,而 big endian 是我们在日常生活中书写数字的方式。我们先写最重要的数字。

因此,解决此问题的一种方法是在发送之前切换 key 的字节顺序:

int key = Convert.ToInt32(endSerial,16);
byte[] bytes = BitConverter.GetBytes(key);
Array.Reverse(bytes); 
key = BitConverter.ToInt32(bytes,0); // now it's in the right order!