好的,所以我有一个项目,我使用客户端(用Lua编写)和服务器(用Java编写)。我使用LuaSocket作为客户端,使用DatagramSockets作为服务器。问题是当我从Lua中的客户端发送一个字符串,并在服务器上接收它(并将字节转换为字符串)时,它不会识别字符串的值等于它应该是什么(我使用.equals()进行评估)。我打印了结果并将其与字符串进行了比较(检查了所有内容);我甚至比较了字节(使用.getBytes()),他们甚至检查了。最讨厌的部分是,当我用.startsWith()分析字符串时,它会计算为true,但没有其他工作。我已经研究了两种语言的字符串编码,但我对套接字来说相对较新,这超出了我的范围。
修改
在编写一些示例代码来演示问题时,我解决了它。这是代码:
客户端:
local socket = require "socket"
local udp = socket.udp()
udp:settimeout(0)
udp:setpeername("localhost", 1234)
udp:send("foo")
服务器:
public class Main
{
public static void main(String args[]) throws Exception
{
DatagramSocket server = new DatagramSocket(1234);
byte[] incomingBytes = new byte[512];
DatagramPacket incomingPacket = new DatagramPacket(incomingBytes, incomingBytes.length);
server.receive(incomingPacket);
String received = new String(incomingBytes);
System.out.println(received);
System.out.println(received.equals("foo"));
for (byte b : received.getBytes())
{
System.out.print(b + " ");
}
System.out.print("\n");
for (byte b : "foo".getBytes())
{
System.out.print(b + " ");
}
System.out.print("\n");
}
}
结果:
foo
false
102 111 111 0 0 0 *I'm not going to include all but there are 506 more*
102 111 111
我之前检查过字节的字符串在几个点被拆分了,这就解释了为什么我没有注意到这一点。
答案 0 :(得分:0)
确实,正如Etan所指出的那样,你要从整个缓冲区创建一个字符串 - 所有512个字节 - 而不是正确长度的字符串,所以创建的字符串有很多零字节端。
一个简单的解决方法是使用String
constructor来切断指定位置和长度的缓冲区,以及从DatagramPacket.getLength
收到的数据包的字节数
更改将received
分配给
String received = new String(incomingBytes, 0, incomingPacket.getLength());