SocketException取消订阅没有onError的请求 [英] SocketException unsubscribing request without onError

查看:39
本文介绍了SocketException取消订阅没有onError的请求的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我正在尝试使用 RxJava 和 Retrofit(2.3) 发出请求.我期待在出现任何错误的情况下,我可以重试或向客户端显示一条消息.

I'm trying to make a request using RxJava and Retrofit(2.3). I'm expecting that in case of any error I can retry or show a message to the client.

但是,我注意到有时我有一个 SocketException 导致不调用 onError,显然请求的订阅者只是取消订阅而不调用其他任何东西(不是 onComplete 也不是 onError).任何人都知道为什么会发生这种情况以及我如何以通用方式解决此问题(无需简单地执行 onUnsubscribe() 并检查 observable 是否未发送任何 onError 或 onComplete)?

However, I notice that sometimes I have a SocketException which results in not calling onError, apparently the subscriber of the request just unsubscribes without calling anything else (not onComplete neither onError). Anyone knows why this is happening and how can I solve this in a generic way (without simply doing onUnsubscribe() and checking if the observable did not send any onError or onComplete)?

在我的界面上,我有这样的东西:

On my interface I have something like this:

@GET("userInfo")
Observable<List<UserInfo>> getUserInfo(@Header("token") String token);

这就是我创建可观察对象的方式:

This is how I create my observable:

    public Observable<UserModel> requestUserInfo(final String token) {
        return mService.getUserInfo(token)
                .retryWhen(new RetryWithDelay(HTTP_RETRIES), HTTP_TIME_BETWEEN_RETRIES)))
                .flatMap(new Func1<List<UserInfo>, Observable<UserModel>() {
                    @Override
                    public Observable<UserModel> call(List<UserInfo> userInfo) {
                        return Observable.just(new UserModel(userInfo));
                    }
                });
    }

------ 更新 -------

------ UPDATE -------

这就是我在演示者上调用 requestUserInfo 方法的方式

This is how I call the requestUserInfo method on my presenter

private CompositeSubscription mCompositeSubscription = null;

 public PresenterX(ViewX view) {
    ...
    mCompositeSubscription = new CompositeSubscription();
 }

public void getUserModel() {
       String userToken = new AccessModel().getUserToken();

        mCompositeSubscription.add(mNetworkRequestModel.requestUserInfo(userToken)
                .flatMap(new Func1<UserModel, Observable<UserModel>>() {
                    @Override
                    public Observable<UserModel> call(UserModel userModel) {
                        if (userModel != null) {
                            saveUserModel(userModel); //sync saving
                            return Observable.just(userModel);
                        } else {
                            return Observable.error(new SaveException());
                        }
                    }
                })
                .subscribeOn(Schedulers.io())
                .observeOn(AndroidSchedulers.mainThread())
                .subscribe(new Subscriber<UserModel>() {
                    @Override
                    public void onCompleted() {
                        Log.i(TAG, "Subscriber was completed")
                    }

                    @Override
                    public void onError(Throwable e) {
                        Log.i(TAG, "Subscriber called onError")
                        mView.handleErrors(e);
                    }

                    @Override
                    public void onNext(UserModel userModel) {
                        Log.i(TAG, "Subscriber called onNext")
                        mView.populateUserInfo(userModel);
                    }
                }));
    }

    //called by activity when onDestroyMethod is called
    //I assume this is not called as I have other requests running parallelly to this getUserModel() and they are not terminated, despite having other compositeSubscription to manage those
    public void onDestroy(){
       mCompositeSubscription.clear();
    }

由于我有一个 HttpLoggingInterceptor,这是请求突然停止时打印给我的唯一日志.

As I have a HttpLoggingInterceptor, this is the only log printed to me while the request suddenly stops.

HttpLoggingInterceptor logging = new HttpLoggingInterceptor(new HttpLoggingInterceptor.Logger() {
            @Override
            public void log(String message) {
                LOG.info(Thread.currentThread(), String.format("%s", message));
        }
    });

这里是日志异常:

I/ExampleApp-ApiClient(21338): : Thread: 1343 |  <-- HTTP FAILED: java.net.SocketException: Socket closed

推荐答案

因为您尝试从服务器获取 rx 对象 (Observable).你的功能不正确移除 Observable

Because you try to get rx object (Observable) from server. You have incorrect function Remove Observable

@GET("userInfo")
List<UserInfo> getUserInfo(@Header("token") String token);

这篇关于SocketException取消订阅没有onError的请求的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆