How to resolve java.net.ConnectException: /ip_address:port - Connection refused exception in android

2.3k views Asked by At

I am getting java.net.ConnectException: /ip_address:port - Connection refused exception.

Here is the code:

public boolean sendMessage(String message, String ip, int port) 
    {
        try {


            Log.i("Log", "Socket Operator IP before split : "+ip);
            String[] str = ip.split("\\.");
            for(int i =0;i<str.length;i++)
            {
                Log.i("Log", "Socket Operator after split : "+str[i]);
            }
            byte[] IP = new byte[str.length];

            for (int i = 0; i < str.length; i++) {

                IP[i] = (byte) Integer.parseInt(str[i]);                
            }               
            Socket socket = getSocket(InetAddress.getByAddress(IP), port);
            if (socket == null) {
                Log.i("Log","Socket Operator SOCKET got null");
                return false;
            }

            PrintWriter out = null;
            out = new PrintWriter(socket.getOutputStream(), true);

            out.println(message);
        } catch (UnknownHostException e) {      
            Log.i("Log","Socket Operator SOCKET got UnknownHostException");
            return false;
            //e.printStackTrace();
        } catch (IOException e) {
            Log.i("Log","Socket Operator SOCKET got IOException");
            e.printStackTrace();
            return false;           
            //e.printStackTrace();
        }
        Log.i("Log","Socket Operator SOCKET got executed");
        return true;        
    }

And Here is my getSocket method:

private Socket getSocket(InetAddress addr, int portNo) 
    {
        Log.i("Log","Socket Operator InetAddress : "+addr.toString()+" Port : "+portNo);            
        Socket socket = null;
        if (sockets.containsKey(addr) == true) 
        {
            Log.i("Log","Socket Operator socket is true");
            socket = sockets.get(addr);
            // check the status of the socket
            if  ( socket.isConnected() == false ||
                  socket.isInputShutdown() == true ||
                  socket.isOutputShutdown() == true ||
                  socket.getPort() != portNo 
                 )  
            {           
                // if socket is not suitable,  then create a new socket
                sockets.remove(addr);               
                try {
                    socket.shutdownInput();
                    socket.shutdownOutput();
                    socket.close();
                    socket = new Socket(addr, portNo);
                    sockets.put(addr, socket);
                } 
                catch (IOException e) {                 
                    Log.e("getSocket: when closing and removing", "");
                }               
            }
        }
        else  
        {
            Log.i("Log","Socket Operator socket is false");
            try {
                Log.i("Log","Socket Operator socket is false in try start");
                socket = new Socket(addr, portNo);
                sockets.put(addr, socket);
            } catch (IOException e) {
                Log.e("getSocket: when creating", "");              
            }                   
        }
        return socket;      
    }

I have followed these links but no luck:

1 https://stackoverflow.com/a/6876306/1395259

2 java.net.ConnectException - Connection Refused Android Emulator

Please help me out to solve this.

Thanks in advance.

1

There are 1 answers

3
skstar On

I encountered similar issue, if you see the message

This will occur when the Port is wrong or blocked or no service:

java.net.ConnectException: failed to connect to /xx.xx.xx.xx (port xx) after xxms: isConnected failed: ECONNREFUSED (Connection refused)

When the IP or host name cannot find in network or blocked and timeout specified you see message like this:

java.net.SocketTimeoutException: failed to connect to /xx.xx.xxx.xx (port xx) after 10000ms

When there is no Network connected on the Device you see the message like this:

java.net.ConnectException: failed to connect to /xx.xx.xx.xxx (port xx) after 10000ms: connect failed: ENETUNREACH (Network is unreachable)


(for the record), internally my API used this method:

com.android.okhttp.internal.http.HttpURLConnectionImpl.execute()

So check the Port number for your case, try with different Port number.