我试图实现一个TCP连接,一切工作良好,从服务器端,但当我运行客户端程序(从客户端计算机),我得到以下错误:

java.net.ConnectException: Connection refused
        at java.net.PlainSocketImpl.socketConnect(Native Method)
        at java.net.PlainSocketImpl.doConnect(PlainSocketImpl.java:351)
        at java.net.PlainSocketImpl.connectToAddress(PlainSocketImpl.java:213)
        at java.net.PlainSocketImpl.connect(PlainSocketImpl.java:200)
        at java.net.SocksSocketImpl.connect(SocksSocketImpl.java:432)
        at java.net.Socket.connect(Socket.java:529)
        at java.net.Socket.connect(Socket.java:478)
        at java.net.Socket.<init>(Socket.java:375)
        at java.net.Socket.<init>(Socket.java:189)
        at TCPClient.main(TCPClient.java:13)

我尝试改变套接字编号,以防它正在使用,但无济于事,有人知道是什么导致了这个错误&如何修复它吗?

服务器代码:

//TCPServer.java

import java.io.*;
import java.net.*;

class TCPServer {
    public static void main(String argv[]) throws Exception {
        String fromclient;
        String toclient;

        ServerSocket Server = new ServerSocket(5000);

        System.out.println("TCPServer Waiting for client on port 5000");

        while (true) {
            Socket connected = Server.accept();
            System.out.println(" THE CLIENT" + " " + connected.getInetAddress()
                    + ":" + connected.getPort() + " IS CONNECTED ");

            BufferedReader inFromUser = new BufferedReader(
                    new InputStreamReader(System.in));

            BufferedReader inFromClient = new BufferedReader(
                    new InputStreamReader(connected.getInputStream()));

            PrintWriter outToClient = new PrintWriter(
                    connected.getOutputStream(), true);

            while (true) {

                System.out.println("SEND(Type Q or q to Quit):");
                toclient = inFromUser.readLine();

                if (toclient.equals("q") || toclient.equals("Q")) {
                    outToClient.println(toclient);
                    connected.close();
                    break;
                } else {
                    outToClient.println(toclient);
                }

                fromclient = inFromClient.readLine();

                if (fromclient.equals("q") || fromclient.equals("Q")) {
                    connected.close();
                    break;
                } else {
                    System.out.println("RECIEVED:" + fromclient);
                }

            }

        }
    }
}

客户端代码:

//TCPClient.java

import java.io.*;
import java.net.*;

class TCPClient {
    public static void main(String argv[]) throws Exception {
        String FromServer;
        String ToServer;

        Socket clientSocket = new Socket("localhost", 5000);

        BufferedReader inFromUser = new BufferedReader(new InputStreamReader(
                System.in));

        PrintWriter outToServer = new PrintWriter(
                clientSocket.getOutputStream(), true);

        BufferedReader inFromServer = new BufferedReader(new InputStreamReader(
                clientSocket.getInputStream()));

        while (true) {

            FromServer = inFromServer.readLine();

            if (FromServer.equals("q") || FromServer.equals("Q")) {
                clientSocket.close();
                break;
            } else {
                System.out.println("RECIEVED:" + FromServer);
                System.out.println("SEND(Type Q or q to Quit):");

                ToServer = inFromUser.readLine();

                if (ToServer.equals("Q") || ToServer.equals("q")) {
                    outToServer.println(ToServer);
                    clientSocket.close();
                    break;
                } else {
                    outToServer.println(ToServer);
                }
            }
        }
    }
}

当前回答

我改变了我的DNS网络,它解决了这个问题

其他回答

对于那些遇到同样问题并使用Spring框架的人,我建议检查http连接提供程序配置。我指的是RestTemplate, WebClient等。

在我的情况下,配置的RestTemplate有一个问题(这只是一个例子):

public RestTemplate localRestTemplate() {
   Proxy proxy = new Proxy(Proxy.Type.HTTP, new InetSocketAddress("localhost", <some port>));
   SimpleClientHttpRequestFactory clientHttpReq = new SimpleClientHttpRequestFactory();
   clientHttpReq.setProxy(proxy);
   return new RestTemplate(clientHttpReq);
}

我只是将配置简化为:

public RestTemplate restTemplate() {
   return new RestTemplate(new SimpleClientHttpRequestFactory());
}

它开始正常工作了。

在我的例子中,服务器是用c#写的,客户端是用Java写的,我通过在服务器中指定主机名为'localhost',在客户端中指定'[::1]'来解决这个问题。我不知道这是为什么,但在客户端指定'localhost'没有工作。 据说这两个词在很多方面都是同义词,但显然不是100%匹配。希望它能帮助人们避免头痛。

我得到了这个错误,因为我在一个for循环中关闭了ServerSocket,试图接受它内部的客户端数量(我没有完成接受所有clints)

所以要小心关闭你的Socket

您必须将客户端套接字连接到远程ServerSocket。而不是

套接字客户端套接字 = 新套接字(“本地主机”, 5000);

do

Socket clientSocket = new Socket(serverName, 5000);

客户端必须连接到serverName, serverName应该与实例化ServerSocket的机器的名称或IP相匹配(该名称必须可以从客户端机器上访问)。顺便说一句:名字并不重要,重要的是IP地址……

我在使用名为vernemq的Mqtt代理时遇到了同样的问题。但通过添加以下内容解决了这个问题。

$ sudo vmq-admin监听显示

显示vernemq允许的ip和端口的列表

$ sudo vmq-admin监听的起始端口=1885 -a 0.0.0.0——mountpoint /appname——nr_of_acceptors=10——max_connections=20000

添加任何IP和您的新端口。现在你应该可以毫无问题地连接了。

希望它能解决你的问题。