Warning: file_get_contents(/data/phpspider/zhask/data//catemap/3/android/214.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Java Android异步任务套接字连接_Java_Android_Sockets_Android Asynctask - Fatal编程技术网

Java Android异步任务套接字连接

Java Android异步任务套接字连接,java,android,sockets,android-asynctask,Java,Android,Sockets,Android Asynctask,我一直在开发一个程序,它通过套接字连接向服务器发送和接收字符串。我使用Asynctask打开连接并发送适当的命令,但无论发生什么事情都不会发生!我知道发送到服务器的命令是绝对正确的,服务器信息是正确的,所以我被难住了 这是我的java代码 new internetRoutesRetrieve().execute(""); private class internetRoutesRetrieve extends AsyncTask<String, Void, String> {

我一直在开发一个程序,它通过套接字连接向服务器发送和接收字符串。我使用Asynctask打开连接并发送适当的命令,但无论发生什么事情都不会发生!我知道发送到服务器的命令是绝对正确的,服务器信息是正确的,所以我被难住了

这是我的java代码

new internetRoutesRetrieve().execute("");

private class internetRoutesRetrieve extends AsyncTask<String, Void, String> {
            @Override
            protected String doInBackground(String... parms) {
                String userNameSend = userName;
                String response = null;
                try {
                    Socket client = new Socket("Hidden", Hidden);
                    DataOutputStream out = new DataOutputStream(client.getOutputStream());
                    DataInputStream in = new DataInputStream(client.getInputStream());
                    String command = "SEARCH " + userNameSend;
                    out.writeUTF(command);
                    out.flush();
                    String responseServer = in.readUTF();
                    out.close();
                    in.close();
                    response = responseServer;
                } catch (UnknownHostException e) {
                    e.printStackTrace();
                } catch (IOException e) {
                    e.printStackTrace();
                }
                return response;
            }
            @Override
            protected void onPostExecute(String result) {
                     //This is always null!
                     System.out.println(result);
                 responseIds = result;
            }
            @Override 
            protected void onPreExecute() {


            }
            @Override
            protected void onProgressUpdate(Void... values) {

            }
        }
}

感谢您的帮助:)

一个EOFEException发出信号,表示输入流在预期的时间之前到达了终点。服务器似乎没有向您发送足够的数据或无效数据

确保在服务器上使用outputStream.writeUTF(…)

    12-09 02:58:52.925: W/System.err(17598): java.io.EOFException
12-09 02:58:53.056: W/System.err(17598):    at libcore.io.Streams.readFully(Streams.java:83)
12-09 02:58:53.056: W/System.err(17598):    at java.io.DataInputStream.readFully(DataInputStream.java:120)
12-09 02:58:53.066: W/System.err(17598):    at java.io.DataInputStream.decodeUTF(DataInputStream.java:195)
12-09 02:58:53.066: W/System.err(17598):    at java.io.DataInputStream.decodeUTF(DataInputStream.java:190)
12-09 02:58:53.066: W/System.err(17598):    at java.io.DataInputStream.readUTF(DataInputStream.java:186)
12-09 02:58:53.066: W/System.err(17598):    at com.example.app.RouteSelection$internetRoutesRetrieve.doInBackground(RouteSelection.java:145)
12-09 02:58:53.066: W/System.err(17598):    at com.example.app.RouteSelection$internetRoutesRetrieve.doInBackground(RouteSelection.java:1)
12-09 02:58:53.066: W/System.err(17598):    at android.os.AsyncTask$2.call(AsyncTask.java:287)
12-09 02:58:53.066: W/System.err(17598):    at java.util.concurrent.FutureTask$Sync.innerRun(FutureTask.java:305)
12-09 02:58:53.066: W/System.err(17598):    at java.util.concurrent.FutureTask.run(FutureTask.java:137)
12-09 02:58:53.066: W/System.err(17598):    at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1076)
12-09 02:58:53.066: W/System.err(17598):    at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:569)
12-09 02:58:53.066: W/System.err(17598):    at java.lang.Thread.run(Thread.java:856)