2016-08-13 258 views
1

當我使用郵差與它的做工精細的點,但與Retrofit2交流,我得到406 Not Acceptable消息如圖所示logcat的。我發現,因此一些相關的問題,我想接受的答案解決方案(添加標頭中的內容類型)但對我不起作用Retrofit2 - 406不可接受

改造配置

public interface AndroidAppService { 
.... 
@Headers({ 
     "Content-Type: text/html; charset=UTF-8" // I also tried application/json 
    }) @GET("subscribers/{msisdn}/verify") Observable<HeaderResponse> checkPhoneNumber(
     @Path("msisdn") String phoneNumber); 
.... 
class Factory { 
public static AndroidAppService create(String baseUrl) { 

    HttpLoggingInterceptor interceptor = new HttpLoggingInterceptor(); 
    interceptor.setLevel(HttpLoggingInterceptor.Level.HEADERS); 
    OkHttpClient client = new OkHttpClient.Builder().addInterceptor(interceptor).build(); 

    Retrofit retrofit = new Retrofit.Builder().baseUrl(baseUrl) 
     .client(client) 
     .addConverterFactory(GsonConverterFactory.create()) 
     .addCallAdapterFactory(RxJavaCallAdapterFactory.create()) 
     .build(); 
    return retrofit.create(AndroidAppService.class); 
    } 
} 
} 

logcat的

08-13 18:59:02.376 17766-22236/com.androidapp D/OkHttp: --> GET http://androidapp.net/bo/web/app_dev.php/api/subscribers/0827873/verify http/1.1 
08-13 18:59:02.376 17766-22236/com.androidapp D/OkHttp: --> END GET 

08-13 18:42:09.512 6350-6927/com.androidapp D/OkHttp: <-- 406 Not Acceptable http://com.androidapp.com 
/bo/web/app_dev.php/api/subscribers/072736263/verify (10680ms) 
08-13 18:42:09.512 6350-6927/com.androidapp D/OkHttp: Date: Sat, 13 Aug 2016 18:58:07 GMT 
08-13 18:42:09.512 6350-6927/com.androidapp D/OkHttp: Server: Apache/2.4.7 (Ubuntu) 
08-13 18:42:09.512 6350-6927/com.androidapp D/OkHttp: X-Powered-By: PHP/5.5.9-1ubuntu4.14 
08-13 18:42:09.512 6350-6927/com.androidapp D/OkHttp: Cache-Control: no-cache 
08-13 18:42:09.512 6350-6927/com.androidapp D/OkHttp: X-Debug-Token: d28d0a 
08-13 18:42:09.512 6350-6927/com.androidapp D/OkHttp: X-Debug-Token-Link: http://com.androidapp/bo/web/app_dev.php/_profiler/d28d0a 
08-13 18:42:09.512 6350-6927/com.androidapp D/OkHttp: Keep-Alive: timeout=5, max=100 
08-13 18:42:09.512 6350-6927/com.androidapp D/OkHttp: Connection: Keep-Alive 
08-13 18:42:09.512 6350-6927/com.androidapp D/OkHttp: Transfer-Encoding: chunked 
08-13 18:42:09.512 6350-6927/com.androidapp D/OkHttp: Content-Type: text/html; charset=UTF-8 
08-13 18:42:09.512 6350-6927/com.androidapp D/OkHttp: OkHttp-Sent-Millis: 1471113729149 
08-13 18:42:09.512 6350-6927/com.androidapp D/OkHttp: OkHttp-Received-Millis: 1471113729517 
08-13 18:42:09.512 6350-6927/com.androidapp D/OkHttp: <-- END HTTP 

回答

1

確定響應並相應地指定Accept標頭。看到這個:https://stackoverflow.com/a/14252326/5250273

提示:找出AcceptContent-Type之間的區別是什麼。

+0

看到我的補充。 –

+0

@謝謝我錯過了'Content-Type'和'Accept'之間的區別 – Abdellah