Я получаю android.os.NetworkOnMainThreadException, когда я использую okhttp с "enqueue" - PullRequest
0 голосов
/ 27 сентября 2019

Я использую okhttp в своем проекте nativescript.Я использую асинхронный запрос, используя enqueue.Но иногда у меня есть android.os.NetworkOnMainThreadException.

Что я делаю не так?

Мой код для отправки запроса в TypeScript:

public okhttpRequest(method: "get" | "post" | "put" | "delete", url: string, options?: {
        body?: string;
        headers?: { [name: string]: string; };
        params?: { [param: string]: string; };
        responseType?: "json";
    }): Observable<Object> {
        // build the request
        const builder = new okhttp3.Request.Builder();

        // method
        switch (method) {
            case "post":
                builder.post(this.createOkhttpRequestBody(options && options.body));
                break;
            case "put":
                builder.put(this.createOkhttpRequestBody(options && options.body));
                break;
            case "delete":
                builder.delete();
                break;
        }

        // headers
        if (options && options.headers) {
            Object.keys(options.headers).forEach(key => {
                builder.header(key, options.headers![key]);
            });
        }

        // URL and parameters
        if (options && options.params) {
            const urlBuilder = okhttp3.HttpUrl.parse(url).newBuilder();
            Object.keys(options.params).forEach(key => {
                urlBuilder.addQueryParameter(key, options.params![key]);
            });
            builder.url(urlBuilder.build().toString());

        } else {
            builder.url(url);
        }

        const request = builder.build();

        const response: Subject<Object> = new Subject(); 

        this.okhttp.newCall(request).enqueue(new okhttp3.Callback({
            onResponse: (call: okhttp3.Call, resp: okhttp3.Response): void => {
                try {
                    this.zone.run(() => {
                        console.log(resp.code());
                        const body = resp.body().string();
                        console.log(body);
                        resp.close();

                        if (this.isResponseOk(resp.code())) {
                            response.next(JSON.parse(body));
                            response.complete();
                        } else {
                            response.error(new HttpWrapperErrorResponse(resp.code(), resp.message()));
                        }
                    });
                } catch (err) {
                    console.log(err);
                    resp.close();
                    response.error(new HttpWrapperErrorResponse(0, err.message));
                }
            },

            onFailure: (call: okhttp3.Call, e: java.io.IOException): void => {
                this.zone.run(() => {
                    response.error(new HttpWrapperErrorResponse(0, e.getMessage()));
                });
            }
        }));

        return response;
    }

Мой след стека:

android.os.NetworkOnMainThreadException  android.os.StrictMode$AndroidBlockGuardPolicy.onNetwork(StrictMode.java:1460)
java.net.SocketInputStream.read(SocketInputStream.java:169)
java.net.SocketInputStream.read(SocketInputStream.java:139)
okio.Okio$2.read(Okio.java:140)
okio.AsyncTimeout$2.read(AsyncTimeout.java:237)
okio.RealBufferedSource.indexOf(RealBufferedSource.java:354)
okio.RealBufferedSource.readUtf8LineStrict(RealBufferedSource.java:226)
okio.RealBufferedSource.readUtf8LineStrict(RealBufferedSource.java:220)
okhttp3.internal.http1.Http1Codec$ChunkedSource.readChunkSize(Http1Codec.java:466)
okhttp3.internal.http1.Http1Codec$ChunkedSource.read(Http1Codec.java:449)
okhttp3.internal.Util.skipAll(Util.java:207)
okhttp3.internal.Util.discard(Util.java:189)
okhttp3.internal.http1.Http1Codec$ChunkedSource.close(Http1Codec.java:487)
okio.RealBufferedSource.close(RealBufferedSource.java:468)
okhttp3.internal.Util.closeQuietly(Util.java:142)
okhttp3.ResponseBody.string(ResponseBody.java:178)
com.tns.Runtime.callJSMethodNative(Native Method)
com.tns.Runtime.access$2300(Runtime.java:34)
com.tns.Runtime$3.run(Runtime.java:1263)
android.os.Handler.handleCallback(Handler.java:808)
android.os.Handler.dispatchMessage(Handler.java:101)
android.os.Looper.loop(Looper.java:166)
android.app.ActivityThread.main(ActivityThread.java:742**strong text**5)
java.lang.reflect.Method.invoke(Native Method)
com.android.internal.os.Zygote$MethodAndArgsCaller.run(Zygote.java:245)
com.android.internal.os.ZygoteInit.main(ZygoteInit.java:921

1 Ответ

0 голосов
/ 27 сентября 2019

Если вы используете okhttp внутри активности, используйте это после получения ответа

activity.this.runonUiThread(new Runnable{
    this.zone.run(() => {
                    console.log(resp.code());
                    const body = resp.body().string();
                    console.log(body);
                    resp.close();

                    if (this.isResponseOk(resp.code())) {
                        response.next(JSON.parse(body));
                        response.complete();
                    } else {
                        response.error(new HttpWrapperErrorResponse(resp.code(), resp.message()));
                    }

});

, если это фрагмент, чем используйте это

       requireActivty.runonUiThread(new RUnnable{
        this.zone.run(() => {
                    console.log(resp.code());
                    const body = resp.body().string();
                    console.log(body);
                    resp.close();

                    if (this.isResponseOk(resp.code())) {
                        response.next(JSON.parse(body));
                        response.complete();
                    } else {
                        response.error(new HttpWrapperErrorResponse(resp.code(), resp.message()));
                    }


});
...