【问题标题】:Java Socket connection from app to java server [duplicate]从应用程序到Java服务器的Java Socket连接[重复]
【发布时间】:2020-02-09 22:43:59
【问题描述】:

我正在设置一个聊天应用程序。我有一个服务器,用 Java 编写,带有套接字,可以完美地连接到 Java 中的示例代码。但是当我在应用程序上尝试与 android studio 完全相同的代码时,由于某种原因它不起作用。

我尝试使用应用程序外部的代码运行它,并且它有效。我已经获得了用户权限,因此它可以连接到互联网。我已尝试连接到控制台上的服务器,并且成功了。

客户:

class Client implements Runnable{
    int freePort;

    @Override
    public void run() {
        connect();
    }

    private void connect(){
        System.out.println("Connecting");
        try {
            Socket socket = new Socket("localhost",1336);
            System.out.println("Connected");
            DataInputStream dataInputStream = new DataInputStream(socket.getInputStream());
            freePort = dataInputStream.readInt();
            System.out.println(freePort);
        } catch (IOException e) {
            e.printStackTrace();
        }

    }

}

服务器:


import java.io.DataInputStream;
import java.io.DataOutputStream;
import java.io.IOException;
import java.net.ServerSocket;
import java.net.Socket;
import java.util.ArrayList;

public class DeclarationServer {
    private int numberOfClients = 0;
    DeclarationServer(){
        try {
            ServerSocket serverSocket = new ServerSocket(1336);
            while (true) {
                System.out.println(serverSocket.getLocalPort() + "__" + serverSocket.getLocalSocketAddress());
                Socket socket = serverSocket.accept();

                System.out.println(socket.getLocalSocketAddress());
                DataInputStream dataInputStream = new DataInputStream(socket.getInputStream());
                dataInputStream.readUTF();
                DataOutputStream dataOutputStream = new DataOutputStream(socket.getOutputStream());
                dataOutputStream.writeInt(1339+numberOfClients);
                dataOutputStream.flush();
                dataOutputStream.close();
                numberOfClients++;
            }
        } catch (IOException e) {
            e.printStackTrace();
        }


    }
}

错误信息:

I/System.out: Connecting
D/ActivityThread: add activity client record, r= ActivityRecord{5f45e99 token=android.os.BinderProxy@712539a {com.example.birke.testapp/com.example.birke.testapp.MainActivity}} token= android.os.BinderProxy@712539a
D/ZrHung.AppEyeUiProbe: notify runnable to start.
W/System.err: java.net.ConnectException: failed to connect to localhost/127.0.0.1 (port 1336) from /:: (port 32940): connect failed: ECONNREFUSED (Connection refused)
        at libcore.io.IoBridge.connect(IoBridge.java:137)
        at java.net.PlainSocketImpl.socketConnect(PlainSocketImpl.java:137)
        at java.net.AbstractPlainSocketImpl.doConnect(AbstractPlainSocketImpl.java:391)
        at java.net.AbstractPlainSocketImpl.connectToAddress(AbstractPlainSocketImpl.java:231)
        at java.net.AbstractPlainSocketImpl.connect(AbstractPlainSocketImpl.java:213)
        at java.net.SocksSocketImpl.connect(SocksSocketImpl.java:436)
        at java.net.Socket.connect(Socket.java:621)
        at java.net.Socket.connect(Socket.java:570)
        at java.net.Socket.<init>(Socket.java:450)
        at java.net.Socket.<init>(Socket.java:218)
W/System.err:     at com.example.birke.testapp.Client.connect(MainActivity.java:151)
        at com.example.birke.testapp.Client.run(MainActivity.java:145)
        at java.lang.Thread.run(Thread.java:784)
    Caused by: android.system.ErrnoException: connect failed: ECONNREFUSED (Connection refused)
        at libcore.io.Linux.connect(Native Method)
        at libcore.io.BlockGuardOs.connect(BlockGuardOs.java:118)
        at libcore.io.IoBridge.connectErrno(IoBridge.java:151)
        at libcore.io.IoBridge.connect(IoBridge.java:129)
        ... 12 more

【问题讨论】:

  • 10.0.2.2 应该是您应该从应用程序连接到的端口。

标签: java android android-studio


【解决方案1】:

看看这一行,

无法从 /:: (port) 连接到 localhost/127.0.0.1 (port 1336) 32940):连接失败:ECONNREFUSED(连接被拒绝)

这意味着,本地主机很可能拒绝连接,服务/服务器没有在特定端口上运行。如果服务器在同一个安卓设备上运行,您将能够连接到 localhost。

解决方案

在初始化Socket时传递服务器的IP(如果客户端和服务器都在同一个网络中,则为私有IP,否则为公共IP)而不是localhost

Socket socket = new Socket("192.168.XXX.XXX",1336);

【讨论】:

    猜你喜欢
    • 2012-04-15
    • 2011-08-24
    • 2018-08-31
    • 1970-01-01
    • 1970-01-01
    • 2017-02-13
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多