有没有更好的方法将 rxjava 用于多个请求?
is there better way using rxjava with multiple requests?
我是 rxjava 或 rxandroid 的新手,正在寻找处理多个请求的更好方法。我需要从服务器获取令牌并将结果用作参数来进行登录验证,如果 returns 成功,则通过 getSessionId 方法获取 sessionId。
我已经考虑过 zip 或 merge,但我认为它不会起作用。那么你能给我一个想法或者我不知道,思路吗?
谢谢。
这是我的代码:
private void getToken(final String name , final String pwd){
api.newToken()
.subscribeOn(Schedulers.newThread())
.observeOn(AndroidSchedulers.mainThread())
.subscribe(new Action1<TokenModel>() {
@Override public void call(TokenModel tokenModel) {
String token = tokenModel.request_token;
if (!"".equals(token)){
login(token, name, pwd);
}else {
Timber.e("got token failed");
}
}
});
}
private void login(String token, String name, String pwd){
api.validateToken(token, name, pwd)
.subscribeOn(Schedulers.newThread())
.observeOn(AndroidSchedulers.mainThread())
.subscribe(new Action1<TokenModel>() {
@Override public void call(TokenModel tokenModel) {
String token = tokenModel.request_token;
if (!"".equals(token)){
getSessionId(token);
}else {
Timber.e("got token failed");
}
}
});
}
private void getSessionId(String token){
api.newSessionn(token)
.subscribeOn(Schedulers.newThread())
.observeOn(AndroidSchedulers.mainThread())
.subscribe(new Observer<TokenModel>() {
@Override public void onCompleted() {
//go to home activity
}
@Override public void onError(Throwable e) {
//handle error
}
@Override public void onNext(TokenModel tokenModel) {
//store session id
}
});
}
您的第一个订阅呼叫您的第二个订阅,...
您可以使用 flapmap 运算符避免这种情况。
api.newToken(...)
.flapMap(token -> api.validateToken(token))
.flapMap(token -> api.newSession(token)).subscribe()
订阅中的新 observable 通常可以由 flatMap 调用替换。
如果你想管理你的错误,在 flatMap 中,如果令牌无效,你可以 return 错误可观察而不是 return 新的 api 调用可观察。
.flatMap(token -> if(token.isValid){ return api.newCall(); } else { return Observable.error(...); ;)
我是 rxjava 或 rxandroid 的新手,正在寻找处理多个请求的更好方法。我需要从服务器获取令牌并将结果用作参数来进行登录验证,如果 returns 成功,则通过 getSessionId 方法获取 sessionId。 我已经考虑过 zip 或 merge,但我认为它不会起作用。那么你能给我一个想法或者我不知道,思路吗? 谢谢。
这是我的代码:
private void getToken(final String name , final String pwd){
api.newToken()
.subscribeOn(Schedulers.newThread())
.observeOn(AndroidSchedulers.mainThread())
.subscribe(new Action1<TokenModel>() {
@Override public void call(TokenModel tokenModel) {
String token = tokenModel.request_token;
if (!"".equals(token)){
login(token, name, pwd);
}else {
Timber.e("got token failed");
}
}
});
}
private void login(String token, String name, String pwd){
api.validateToken(token, name, pwd)
.subscribeOn(Schedulers.newThread())
.observeOn(AndroidSchedulers.mainThread())
.subscribe(new Action1<TokenModel>() {
@Override public void call(TokenModel tokenModel) {
String token = tokenModel.request_token;
if (!"".equals(token)){
getSessionId(token);
}else {
Timber.e("got token failed");
}
}
});
}
private void getSessionId(String token){
api.newSessionn(token)
.subscribeOn(Schedulers.newThread())
.observeOn(AndroidSchedulers.mainThread())
.subscribe(new Observer<TokenModel>() {
@Override public void onCompleted() {
//go to home activity
}
@Override public void onError(Throwable e) {
//handle error
}
@Override public void onNext(TokenModel tokenModel) {
//store session id
}
});
}
您的第一个订阅呼叫您的第二个订阅,...
您可以使用 flapmap 运算符避免这种情况。
api.newToken(...)
.flapMap(token -> api.validateToken(token))
.flapMap(token -> api.newSession(token)).subscribe()
订阅中的新 observable 通常可以由 flatMap 调用替换。
如果你想管理你的错误,在 flatMap 中,如果令牌无效,你可以 return 错误可观察而不是 return 新的 api 调用可观察。
.flatMap(token -> if(token.isValid){ return api.newCall(); } else { return Observable.error(...); ;)