读取输入流onMainThreadException Android

时间:2013-08-24 09:05:04

标签: android networkonmainthread

我正在尝试从我的服务器获取信息,因此我发送请求以获得响应:

private InputStream getInputStreamFromUrl(String url) {
    InputStream content = null;
    try {
        HttpClient httpclient = new DefaultHttpClient();
        HttpResponse response = httpclient.execute(new HttpGet(url));
        content = response.getEntity().getContent();
    } catch (Exception e) {
        Log.v(TAG, "Network exception", e);
    }
    return content;
}

我创建了一个异步任务来准备我的请求

public class HttpRequestTask extends AsyncTask<Request, Integer, Request[]>
{
HttpRequestTaskListner httpRequestTaskListner;

public void setHttpRequestTaskListner(HttpRequestTaskListner httpRequestTaskListner){
    this.httpRequestTaskListner = httpRequestTaskListner;
}

protected Request[] doInBackground(Request...requests){
    for(int i = 0; i<requests.length; i++){
        requests[i].execute();
    }
    return requests;
}

protected void onPostExecute(Request[] requests){
    if(requests != null){
        httpRequestTaskListner.httpRequestTaskSuccess(requests);
    }
    else{
        httpRequestTaskListner.HttpRequestTaskFailed();
    }
}

public static interface HttpRequestTaskListner{
    void httpRequestTaskSuccess(Request[] requests);
    void HttpRequestTaskFailed();
}
}

我执行了我的请求

public void register(final ResultListner resultListner)
{

    //define url
    String url = webServiceUrl;
    url += prop.getProperty("register");
    //TODO change mobile id
    url += "?mobile_id=test";
    url += "&app_id="+prop.getProperty("applicationId");

    //send request
    Request request = new Request(url);
    HttpRequestTask httpRequestTask = new HttpRequestTask();
    httpRequestTask.setHttpRequestTaskListner(new HttpRequestTaskListner() {



        @Override
        public void httpRequestTaskSuccess(Request[] requests) {
            resultListner.onResultSuccess(requests);
        }

        @Override
        public void HttpRequestTaskFailed() {
            resultListner.onResultFail();
        }
    });
    httpRequestTask.execute(request);
}

要完成我使用活动中的代码

Server server = new Server(getApplicationContext());
    server.register(new ResultListner() {

        @Override
        public void onResultSuccess(Request[] request) {
            InputStream is = request[0].getResult();
            String result = Util.getStringFromInputStream(is);
            if(result.equals(Server.REGISTER_SUCCESS)){
                System.out.println("aa");
            }
            else{
                //TODO register error
            }
        }

        @Override
        public void onResultFail() {
            // TODO fail request
        }
    });

有时我得到一个OnMainTheradException但是我不知道为什么有时它会起作用,有时候我得到了例外,这很奇怪

日志:

08-24 17:00:35.630: E/AndroidRuntime(7265): FATAL EXCEPTION: main
08-24 17:00:35.630: E/AndroidRuntime(7265): android.os.NetworkOnMainThreadException
08-24 17:00:35.630: E/AndroidRuntime(7265):     at     android.os.StrictMode$AndroidBlockGuardPolicy.onNetwork(StrictMode.java:1118)
08-24 17:00:35.630: E/AndroidRuntime(7265):     at     libcore.io.BlockGuardOs.recvfrom(BlockGuardOs.java:163)
08-24 17:00:35.630: E/AndroidRuntime(7265):     at     libcore.io.IoBridge.recvfrom(IoBridge.java:513)
08-24 17:00:35.630: E/AndroidRuntime(7265):     at java.net.PlainSocketImpl.read(PlainSocketImpl.java:488)
08-24 17:00:35.630: E/AndroidRuntime(7265):     at java.net.PlainSocketImpl.access$000(PlainSocketImpl.java:46)
08-24 17:00:35.630: E/AndroidRuntime(7265):     at java.net.PlainSocketImpl$PlainSocketInputStream.read(PlainSocketImpl.java:240)
08-24 17:00:35.630: E/AndroidRuntime(7265):     at org.apache.http.impl.io.AbstractSessionInputBuffer.fillBuffer(AbstractSessionInputBuffer.java:103)
08-24 17:00:35.630: E/AndroidRuntime(7265):     at org.apache.http.impl.io.AbstractSessionInputBuffer.readLine(AbstractSessionInputBuffer.java:191)
08-24 17:00:35.630: E/AndroidRuntime(7265):     at org.apache.http.impl.io.ChunkedInputStream.getChunkSize(ChunkedInputStream.java:220)
08-24 17:00:35.630: E/AndroidRuntime(7265):     at org.apache.http.impl.io.ChunkedInputStream.nextChunk(ChunkedInputStream.java:183)
08-24 17:00:35.630: E/AndroidRuntime(7265):     at org.apache.http.impl.io.ChunkedInputStream.read(ChunkedInputStream.java:155)
08-24 17:00:35.630: E/AndroidRuntime(7265):     at org.apache.http.conn.EofSensorInputStream.read(EofSensorInputStream.java:159)
08-24 17:00:35.630: E/AndroidRuntime(7265):     at java.io.InputStreamReader.read(InputStreamReader.java:244)
08-24 17:00:35.630: E/AndroidRuntime(7265):     at java.io.Reader.read(Reader.java:145)
08-24 17:00:35.630: E/AndroidRuntime(7265):     at java.io.Reader.read(Reader.java:258)
08-24 17:00:35.630: E/AndroidRuntime(7265):     at java.util.Scanner.readMore(Scanner.java:2137)
08-24 17:00:35.630: E/AndroidRuntime(7265):     at java.util.Scanner.findPostDelimiter(Scanner.java:2107)
08-24 17:00:35.630: E/AndroidRuntime(7265):     at java.util.Scanner.setTokenRegion(Scanner.java:2017)
08-24 17:00:35.630: E/AndroidRuntime(7265):     at java.util.Scanner.next(Scanner.java:1004)
08-24 17:00:35.630: E/AndroidRuntime(7265):     at java.util.Scanner.next(Scanner.java:980)
08-24 17:00:35.630: E/AndroidRuntime(7265):     at com.easyapp.util.Util.getStringFromInputStream(Util.java:27)
08-24 17:00:35.630: E/AndroidRuntime(7265):     at com.easyapp.application.MainActivity$1.onResultSuccess(MainActivity.java:31)
08-24 17:00:35.630: E/AndroidRuntime(7265):     at com.easyapp.server.Server$1.httpRequestTaskSuccess(Server.java:49)
08-24 17:00:35.630: E/AndroidRuntime(7265):     at com.easyapp.server.HttpRequestTask.onPostExecute(HttpRequestTask.java:22)
08-24 17:00:35.630: E/AndroidRuntime(7265):     at com.easyapp.server.HttpRequestTask.onPostExecute(HttpRequestTask.java:1)
08-24 17:00:35.630: E/AndroidRuntime(7265):     at android.os.AsyncTask.finish(AsyncTask.java:631)
08-24 17:00:35.630: E/AndroidRuntime(7265):     at android.os.AsyncTask.access$600(AsyncTask.java:177)
08-24 17:00:35.630: E/AndroidRuntime(7265):     at android.os.AsyncTask$InternalHandler.handleMessage(AsyncTask.java:644)
08-24 17:00:35.630: E/AndroidRuntime(7265):     at android.os.Handler.dispatchMessage(Handler.java:99)
08-24 17:00:35.630: E/AndroidRuntime(7265):     at android.os.Looper.loop(Looper.java:137)
08-24 17:00:35.630: E/AndroidRuntime(7265):     at android.app.ActivityThread.main(ActivityThread.java:4895)
08-24 17:00:35.630: E/AndroidRuntime(7265):     at java.lang.reflect.Method.invokeNative(Native Method)
08-24 17:00:35.630: E/AndroidRuntime(7265):     at java.lang.reflect.Method.invoke(Method.java:511)
08-24 17:00:35.630: E/AndroidRuntime(7265):     at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:994)
08-24 17:00:35.630: E/AndroidRuntime(7265):     at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:761)
08-24 17:00:35.630: E/AndroidRuntime(7265):     at dalvik.system.NativeStart.main(Native Method)

第27行的错误Util.java是

public static String getStringFromInputStream(InputStream is)
{
    if(is == null){
        return null;
    }

    return new Scanner(is,"UTF-8").useDelimiter("\\A").next();
}

return new Scanner(is,"UTF-8").useDelimiter("\\A").next();

2 个答案:

答案 0 :(得分:2)

我认为android.os.NetworkOnMainThreadException解决方案是....

添加:

StrictMode.ThreadPolicy policy = new StrictMode.ThreadPolicy.Builder().permitAll().build();

StrictMode.setThreadPolicy(policy); 

在你班上,

将此添加到ManiFestFile:

<uses-permission android:name="android.permission.INTERNET"/>

答案 1 :(得分:0)

  1. 不要使用strictMode(仅限于调试模式)
  2. 请勿更改SDK版本
  3. 使用服务 AsyncTask

    good tutorial可帮助您入门。