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 № 1Ok, 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 =)