/ / Retrofit2: Nie znaleziono HTTP 404 - android, rx-java, retrofit2

Retrofit2: Nie znaleziono HTTP 404 - android, rx-java, retrofit2

Mam tę prostą usługę na moim serwerze na http://192.168.1.12:8080/api/hooray:

router.route("/hooray/")
.get(function (req, res) {
res.status(200).send({ result: true, message: "hooray" })
})

Działa z Postman, ale z mojej aplikacji na Androida nie mogę uzyskać dostępu do tego adresu URL i nie wiem dlaczego.

To jest (uproszczony) kod:

Interfejs usługi

public interface HoorayAPI {
@GET("hooray/")
Observable<HoorayResponse> hooray();
}

Moja niestandardowa klasa odpowiedzi: HoorayResponse

public class HoorayResponse{
@SerializedName("result")
@Expose
private boolean result;

@SerializedName("message")
@Expose
private String message;

public HoorayResponse(boolean result, String message) {
this.result = result;
this.message = message;
}

// Getter and setter ...
}

Gość

public void foo(){
Retrofit retrofit = new Retrofit.Builder()
.baseUrl("http://192.168.1.12:8080/api/")
.addCallAdapterFactory(RxJavaCallAdapterFactory.create())
.addConverterFactory(GsonConverterFactory.create())
.build();

HoorayAPI service = retrofit.create(HoorayAPI.class);

Observable<HoorayResponse> hoorayObservable = service.hooray();

hoorayObservable
.subscribeOn(Schedulers.newThread())
.observeOn(AndroidSchedulers.mainThread())
.subscribe(new Subscriber<HoorayResponse>() {
@Override
public void onCompleted() {}

@Override
public void onError(Throwable e) { e.printStackTrace(); }

@Override
public void onNext(HoorayResponse response) {
System.out.println("Hooray!!!");
}
});
}

Kiedy wołam metodę foo (), pojawia się ten błąd:

retrofit2.adapter.rxjava.HttpException: HTTP 404 Not Found
at retrofit2.adapter.rxjava.OperatorMapResponseToBodyOrError$1.onNext(OperatorMapResponseToBodyOrError.java:43)
at retrofit2.adapter.rxjava.OperatorMapResponseToBodyOrError$1.onNext(OperatorMapResponseToBodyOrError.java:38)
at retrofit2.adapter.rxjava.RxJavaCallAdapterFactory$RequestArbiter.request(RxJavaCallAdapterFactory.java:173)
at rx.internal.operators.OperatorSubscribeOn$1$1$1.request(OperatorSubscribeOn.java:80)
at rx.Subscriber.setProducer(Subscriber.java:211)
at rx.internal.operators.OperatorSubscribeOn$1$1.setProducer(OperatorSubscribeOn.java:76)
at rx.Subscriber.setProducer(Subscriber.java:205)
at retrofit2.adapter.rxjava.RxJavaCallAdapterFactory$CallOnSubscribe.call(RxJavaCallAdapterFactory.java:152)
at retrofit2.adapter.rxjava.RxJavaCallAdapterFactory$CallOnSubscribe.call(RxJavaCallAdapterFactory.java:138)
at rx.internal.operators.OnSubscribeLift.call(OnSubscribeLift.java:50)
at rx.internal.operators.OnSubscribeLift.call(OnSubscribeLift.java:30)
at rx.Observable.unsafeSubscribe(Observable.java:8460)
at rx.internal.operators.OperatorSubscribeOn$1.call(OperatorSubscribeOn.java:94)
at rx.internal.schedulers.ScheduledAction.run(ScheduledAction.java:55)
at java.util.concurrent.Executors$RunnableAdapter.call(Executors.java:428)
at java.util.concurrent.FutureTask.run(FutureTask.java:237)
at java.util.concurrent.ScheduledThreadPoolExecutor$ScheduledFutureTask.run(ScheduledThreadPoolExecutor.java:272)
at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1133)
at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:607)
at java.lang.Thread.run(Thread.java:776)

Nie mogę się domyślić, ponieważ błąd: Nie znaleziono HTTP 404. Ta usługa jest dostępna i działa. Napisałem API usługi dla Zaloguj Się w bardzo podobny sposób do HoorayAPI, z metodą POST i działa. Dlaczego to nie działa tutaj? Mam na myśli, że kod wydaje się być poprawny.

Odpowiedzi:

1 dla odpowiedzi № 1

Ok, znajduję odpowiedź. Problem polegał na tym

.baseUrl("http://192.168.1.12:8080/api/")

Był pod tagiem ciąg

<string name="url">http://192.168.1.12:8080/api/</string>

w getResources (). getString (R.string.url).

Miałem tę sytuację w pliku string.xml:

<string name="url">http://192.168.1.12:8080/api/</string>
<!--<string name="url">https://myapp-api.mydomain.io/api</string> -->

i dziwnie, nawet jeśli ten drugi został skomentowany, program rozpoznaje go (https://myapp-api.mydomain.io/api) jako adres URL


0 dla odpowiedzi nr 2

Czy jesteś pewien, że telefon komórkowy jest podłączony do tej samej sieci LAN?

W przeciwnym razie możesz spróbować usunąć ukośnik końcowy interfejsu, ale nie powinno to być problemem

public interface HoorayAPI {
@GET("hooray")
Observable<HoorayResponse> hooray();
}

0 dla odpowiedzi № 3

Powinieneś zmienić typ swojego subscribeOn(Schedulers.newThread()) do tego .subscribeOn(Schedulers.single()) Pomaga mi to =)