[英]A socket with c server over java socket
我的任务要求我用 c 编写服务器,但用 java 编写客户端。 我需要向我的客户发送一些整数作为说明。 他们可以顺利连接,但我的 java 客户端无法接收从 c 服务器发送的整数。 只有两种可能性:我的 c 服务器没有发送数字或者我的客户端没有正确接收整数。 c 服务器能够在我输入时循环,因为 printf 和 scanf 是在客户端没有发生任何事情时执行的。
我被困在这里,任何帮助将不胜感激!
================================================== ======================== 更新:我更正了java中的主类,其中客户端的类名变成了dotClient,并且我的客户端能够连接和从服务器读取输入。 我尝试在服务器端直接发送一个“int”,但是当客户端(java)使用 DataInputStream.ReadInt() 时,它返回一个随机的大数,就好像 c 中 int 的大小和 java 中 int 的大小是不匹配。当我使用ac客户端做同样的工作时,它工作正常。 因此,直接在 ac 服务器上使用 dataInputStream 存在隐藏问题,因为我也尝试过 readShort() 和 ReadLong()。
按照建议,我使用 bufferReader。 并在服务器端发送字符串,并在客户端将其转换为 int。 有用。
这是我更新的 c 代码
#define PORT 55555
int main(int argc, char const *argv[])
{
int server_fd, new_socket, valread;
struct sockaddr_in address;
int opt = 1;
int addrlen = sizeof(address);
char buffer[1024];
int returnSend = 0;
// Creating socket file descriptor
if (
(server_fd = socket(AF_INET, SOCK_STREAM, 0))
== 0)
{
perror("socket failed");
exit(EXIT_FAILURE);
}
printf("%s\n", "Socket created!");
// Forcefully attaching socket to the port 8080
if (setsockopt(server_fd, SOL_SOCKET,
SO_REUSEPORT, &opt, sizeof(opt)))
{
perror("setsockopt");
exit(EXIT_FAILURE);
}
printf("Socket attached!\n");
address.sin_family = AF_INET;
address.sin_addr.s_addr = INADDR_ANY;
address.sin_port = htons( PORT );
// Forcefully attaching socket to the port 8080
if (bind(server_fd,
(struct sockaddr *)&address,
sizeof(address))<0)
{
perror("bind failed");
exit(EXIT_FAILURE);
}
printf("socket binded!\n");
if (listen(server_fd, 3) < 0)
{
perror("listen");
exit(EXIT_FAILURE);
}
printf("socket listened!\n");
if ((new_socket = accept(server_fd,
(struct sockaddr *)&address,
(socklen_t*)&addrlen))<0)
{
perror("accept");
exit(EXIT_FAILURE);
}// Socket formulated !
do{
fgets(buffer, sizeof(buffer), stdin);
returnSend = write(new_socket , buffer , strlen(buffer));
printf("Sending: %sReturn returnSend: %d.\n", buffer,returnSend);
} while (1);
return 0;
}
这是我更新的 Java 客户端
import java.net.*;
import java.io.*;
public class dotClient
{
// initialize socket and input output streams
private Socket echoSocket= null;
private BufferedReader input = null;
// constructor to put ip address and port
public dotClient(String address, int port)
{
// establish a connection
try
{
echoSocket = new Socket(address, port);
System.out.println("Connected");
input =
new BufferedReader(
new InputStreamReader(echoSocket.getInputStream()));
}
catch(UnknownHostException u)
{
System.out.println("exception 1: "+u);
}
catch(IOException i)
{
System.out.println("exception 2: "+i);
}
int number = 0;
String line = "";
// keep reading until read neagaive integer
try
{
while ((line = input.readLine()) != null)
{
number = Integer.parseInt(line);
System.out.println("String is :"+line);
System.out.println("number is :"+number);
}
}
catch(IOException i)
{
System.out.println("Exception 3: "+i);
}
// close the connection
try
{
input.close();
out.close();
echoSocket.close();
System.out.println("Connection closed!");
}
catch(IOException i)
{
System.out.println("Exception 4: "+i);
}
}
public static void main(String args[])
{
dotClient client = new dotClient("192.168.0.3", 55555);
}
}
在您的main
方法中,您正在创建一个Client
实例,但您的类称为dotClient
。 您可能希望确保您正在创建类dotClient
的实例。 否则我同意之前的评论,并会为 IO 建议使用 BufferedReader 和 BufferedWriter/PrintWriter。
您的任何 try 块是否在客户端捕获异常? 检查send(new_socket , &number , size(number) , 0 );
的返回值send(new_socket , &number , size(number) , 0 );
在服务器上以确保数据实际上已发送以获取更多信息,请查看http://man7.org/linux/man-pages/man2/send.2.html 。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.