Android Socket Exception "сокет закрыт" - PullRequest
5 голосов
/ 12 января 2012

Когда я пытаюсь запустить тест, состоящий из эхо-сервера и Android-клиента со следующим кодом, я всегда получаю исключение msg "сокет закрыт". Этот код может просто отправлять сообщения на сервер и получать сообщения от сервера, но если вы хотите сделать и то и другое одновременно, он просто не работает ... Мне очень любопытно, почему это приведет к такого рода проблемам, и как мне это исправить, если я хочу, чтобы он мог сначала отправить сообщение на эхо-сервер

и затем получать сообщения от эхо-сервера?

            // Server IP address 
            InetAddress serverIp;

            // try to connect Server
            try {

                // set up server IP address
                serverIp = InetAddress.getByName("192.168.17.1");

                // set up port
                int serverPort=12345;

                // initiate socket connection
                Socket clientSocket=new Socket(serverIp,serverPort);

                BufferedOutputStream out = new BufferedOutputStream(clientSocket.getOutputStream());
                out.write("Send From Android1111, stitch ".getBytes());
                out.flush();

                //wait to receive Server's msg 
                BufferedReader  br =new BufferedReader(new InputStreamReader(clientSocket.getInputStream())); 

                total.toString();*/
            // Display received msg with Toast
                Toast.makeText(getApplicationContext(), br.readLine(), Toast.LENGTH_SHORT ).show();

            //close connection
                clientSocket.close();             

//              out.close();
//              out = null;
            } catch (IOException e) {
                // display exception with Toast
                Toast.makeText(getApplicationContext(),e.toString(), Toast.LENGTH_SHORT).show();
            }

к сожалению, он все еще не работает ... Я выполнил вашу инструкцию и изменил код на:

            // set up Server IP address 
            serverIp = InetAddress.getByName("192.168.2.2");

            // set up Server port
            int serverPort=12345;

            // initiate socket connection
            Socket clientSocket=new Socket(serverIp,serverPort);

                // open input and output stream
            OutputStream out = clientSocket.getOutputStream();
            InputStream in = clientSocket.getInputStream();

            //send msg
            out.write("Send From Android1111, bitch ".getBytes());


                // receive msg from server
            byte[] buffer = new byte[in.available()];
            in.read(buffer);
            String rMsg = new String(buffer);
            Toast.makeText(getApplicationContext(), rMsg, Toast.LENGTH_LONG ).show();

            //close input and output stream
            in.close();
            out.close();

             //關閉連線
       clientSocket.close(); 
        } catch (IOException e) {
            // 出錯後顯示錯誤訊息Toast
            Toast.makeText(getApplicationContext(),e.toString(), Toast.LENGTH_SHORT).show();
        }

для удобства, вот код, написанный на Python для серверной части:

# Practice Echo Server Program written in Python
import socket

# host = '' means it binds to any available interface
host = ''
port = 12345

# socket() function returns a socket object whose methods implement the various socket system calls.
s = socket.socket(socket.AF_INET,socket.SOCK_STREAM)

# Bind the socket to address. 
s.bind((host,port))

# Listen for connections made to the socket. The backlog argument specifies 
# the maximum number of queued connections and should be at least 0; 
# the maximum value is system-dependent (usually 5), the minimum value is forced to 0.
s.listen(5)

# Accept a connection. The socket must be bound to an address and listening for 
# connections. The return value is a pair (conn, address) where conn is a new socket 
# object usable to send and receive data on the connection, and address is the address
# bound to the socket on the other end of the connection.
conn, addr = s.accept()
print 'Connected by', addr

# Receive data from the socket. The return value is a string representing the data received.
# The maximum amount of data to be received at once is specified by bufsize. See the Unix
# manual page recv(2) for the meaning of the optional argument flags; it defaults to zero.
# Note For best match with hardware and network realities, the value of bufsize should be 
# a relatively small power of 2, for example, 4096.

while 1:
    data = conn.recv(1024)
    if not data: break 
    print 'received data is : ', repr(data)
    conn.send(data)

conn.close()

Ответы [ 3 ]

5 голосов
/ 12 января 2012

Я полагаю, вы делаете правильные вещи в неправильном порядке.Возможно, сервер работает слишком быстро, и когда вы пытаетесь прочитать ответ, он уже получен и ушел.

В соответствии с правилами, представленными в руководстве Чтение и запись в сокет

  1. Открыть сокет
  2. Открыть входной поток и поток вывода в сокет.
  3. Чтение и запись в поток в соответствии с протоколом сервера.
  4. Закрыть потоки.
  5. Закройте розетку.

Видите разницу?Сначала откройте поток ввода и вывода, а затем начните отправку запроса.

Я уверен, что если вы будете придерживаться этого порядка, он будет работать.

0 голосов
/ 04 апреля 2018

У меня была похожая проблема, я решил ее, отредактировав файл gradle.properties для подключения прокси.Я добавил вышеприведенные строки, как объяснил Надим Шайк https://github.com/facebook/react-native/issues/2726

systemProp.http.proxyHost=proxyHost
systemProp.http.proxyPort=proxyPort

systemProp.https.proxyHost=proxyHost
systemProp.https.proxyPort=proxyPort
0 голосов
/ 13 января 2012

Вашему приложению требуется разрешение ИНТЕРНЕТ в вашем AndroidManifest.xml

<uses-permission android:name="android.permission.INTERNET"/>
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...