[英]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.