我有一个TCP客户端 - 服务器架构。 Server用C#编写,Client用Java编写。 我想获取客户端设备的MAC地址。两者之间的连接正在起作用当我发送数据" IPMAC" 的数据包时,它会被正确接收和解码。 但是当我将MAC地址发送到服务器时,它会更改其中的数据。
用于发送的Java代码:
InetAddress ip;
try {
ip = InetAddress.getLocalHost();
NetworkInterface network = NetworkInterface.getByInetAddress(ip);
byte[] mac = network.getHardwareAddress();
StringBuilder sb = new StringBuilder();
for (int i = 0; i < mac.length; i++) {
sb.append(String.format("%02X%s", mac[i], (i < mac.length - 1) ? "-" : ""));
}
outStream.write(sb.toString().getBytes("UTF-8"));
System.out.println("Data sent " + sb.toString());
} catch (IOException e) {
System.out.println("Unable to get MAC address of device or send it to server");
}
接收的C#代码:
size = 6;
byte[] buffer = new byte[6];
int received = 0;
ticks = Environment.TickCount;
do
{
try
{
if (Environment.TickCount > ticks + timeout)
throw new TimeoutException("Timout while receiving!");
received = received + client.Client.Receive(buffer, received, size - received, SocketFlags.None);
}
catch (SocketException)
{
}
catch (TimeoutException)
{
break;
}
if (buffer.Length > 1)
{
MessageBox.Show("Packet received!", "Wow", MessageBoxButton.OK, MessageBoxImage.Information);
StringBuilder sb = new StringBuilder();
for (int i = 0; i < buffer.Length; i++)
{
sb.Append(String.Format("%02X%s", buffer[i], (i < buffer.Length - 1) ? "-" : ""));
}
Console.WriteLine(BitConverter.ToString(buffer));
break;
}
}
while (received < size);
我在两边都使用 UTF-8 编码。
发送的MAC地址:00-08-BA-11-00
收到的MAC地址:A1-21-00-00-00
由于
答案 0 :(得分:1)
您希望确保将字节解码为UTF-8
Console.WriteLine(System.Text.Encoding.UTF8.GetString(buffer));
在java中,您获取表示整数byte[] mac
的字节,并对它们String.format("%02X%s"...
执行字符串格式。你拿这个字符串,把它变成字节并通过套接字发送。您在C#端接收的字节表示UTF-8字符,不是整数,因此请勿尝试再次对它们进行字符串格式化。删除C#客户端上的StringBuilder
,然后将字节解码为上面的utf8字符串。
另外,为什么选择接收字节大小为size = 6;
?如果有超过6个字节的数据怎么办? utf8中的字符串"00-08-BA-11-00"
长度为14个字节!
一种解决方案可能是在发送数据之前发送数据大小。如果你感兴趣的话,我在其他星期要求code review类似的东西!