2015-09-27 84 views
3

你好我試圖解析成一個列表下面的JSON響應獲取JSON數組與改造

{"beers":[{"id":"1","nombre":"Larzobispa","localidad":"Alcorcon","provincia":"Madrid"},{"id":"2","nombre":"La Cibeles","localidad":"Madrid","provincia":"Madrid"}]} 

林AbebeerApi

Retrofit retrofit = new Retrofit.Builder() 
    .baseUrl("end_point_url") 
    .build(); 

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

並呼叫創建的服務

List<SingleBeer> beers = service.listBeers(); 

我沒有得到啤酒列表中的任何響應。我的應用程序關閉,我在logcat中沒有任何信息。

這是我的POJO類

public class SingleBeer { 
    int id; 
    String nombre; 
    String localidad; 
    String provincia; 

//getters and setters 
    } 

能有人幫幫我嗎? 預先感謝您

編輯:我讓你在的情況下我的PHP代碼有什麼不對的地方

if (mysql_num_rows($result) > 0) { 
// looping through all results 
$response["beers"] = array(); 

while ($row = mysql_fetch_array($result)) { 

    $beers = array(); 
    $beers["id"] = $row["id"]; 
    $beers["nombre"] = $row["nombre"]; 
    $beers["localidad"] = $row["localidad"]; 
    $beers["provincia"] = $row["provincia"]; 

    // push single product into final response array 
    array_push($response["beers"], $beers); 
} 
// success 
$response["succes"] = 1; 

// echoing JSON response 
echo json_encode($response); 
mysql_close($localhost); 
} else { 
    // no products found 
    $response["success"] = 0; 
    $response["message"] = "No beers have found"; 

    // echo no users JSON 
    echo json_encode($response); 
    mysql_close($localhost); 
} 

編輯2:我的問題解決了這個職位 https://stackoverflow.com/a/27698866/4669063

我創建將LenientGsonConverter類添加到我的RestAdapter的setConverter方法中

+1

看起來您在構建適配器時需要添加轉換器。看到這個答案http://stackoverflow.com/a/32390665/1904517 – iagreen

+0

謝謝你的評論,但仍無法與回答工作.... – Bruno

+0

我只是改變我的代碼,並使用改進1.9.0,但仍然沒有工作。如果我使用https://api.github.com/users,我可以得到列表中的所有用戶,但是當我想讓我的Json不起作用時。它具有相同的結構...... [{ 「ID」: 「1」, 「農佈雷」: 「香格里拉arzobispa」, 「localidad」: 「艾科坎」, 「省報」: 「馬德里」},{ 「ID」:」 2" , 「農佈雷」: 「拉一同慶祝」, 「localidad」: 「馬德里」, 「省報」: 「馬德里」}] – Bruno

回答

1

結構不完全相同。您的回覆有一個對象,其中有一個名爲beers的字段,它是一系列啤酒。你需要反序列化對象 -

class Beers { 
    List<SingleBeer> beers; 
} 

更新你的界面 -

public interface AbebeerApi { 
    @GET("/beer_app/beers") 
    Beers listBeers(); 
} 

,您的電話 -

Beers beerContainer = service.listBeers(); 

和訪問啤酒名單雖然beerContain.beers或等效的getter 。

+0

是我改變JSON響應於:[{ 「ID」: 「1」,」農佈雷 「:」 拉arzobispa」, 「localidad」: 「阿爾戈爾貢」, 「省報」: 「馬德里」},{ 「ID」: 「2」, 「農佈雷」: 「拉一同慶祝」, 「localidad」: 「馬德里」 ,「provincia」:「Madrid」}]獲得相同的結構(使用字符串ID),但仍然無法正常工作...我也嘗試了您的代碼,但無法正常工作。謝謝你的時間, – Bruno

+1

看看你是否可以得到一個logcat。這將有助於縮小範圍 – iagreen

+0

在服務中,方法成功並失敗,我知道代碼在logcat中獲取日誌時運行失敗。 @Override 公共無效失敗(錯誤RetrofitError){ Log.i( 「TEST」, 「ERROR」);}。如果您發現有問題,請讓我的網址http://abdevelopers.site88.net/beer_app/beers/ – Bruno

2
RestAdapter retrofit= new RestAdapter.Builder().setEndpoint("end_point_url") 
       .build(); 
AbebeerApi service = retrofit.create(AbebeerApi.class); 
service.getBeer(new Callback<BeerResponse>() { 

      @Override 
      public void success(BeerResponse beerResponse, Response res) { 
       // Use beerResponse for response 
      } 

      @Override 
      public void failure(RetrofitError error) { 
      } 
     }); 

這是您的界面。你應該添加回調方法。在回調中,你應該通過你的POJO。

public interface AbebeerApi { 
    @GET("/beer_app/beers") 
    public void getBeer(Callback<BeerResponse> callback) 
} 

我在回答這個api。

{"beers":[{"id":"1","nombre":"Larzobispa","localidad":"Alcorcon","provincia":"Madrid"},{"id":"2","nombre":"La Cibeles","localidad":"Madrid","provincia":"Madrid"}]} 

問題是你試圖直接通過名單。你應該創建兩個類來獲得響應。第一個BeerResponse僅用於列表,第二個類中您應該聲明您的json對象意味着id,nombre和all.Moreover主要導入的東西是您的api字段名稱和您的POJO的字段名稱必須相同。如果您想更改POJO的字段名稱,則可以使用GSON註釋@SerializedName。

public class BeerResponse{ 
List<SingleBeer> beers; 

//getters and setters 
} 

public class SingleBeer { 
    int id; 
    String nombre; 
    String localidad; 
    String provincia; 

//getters and setters 
} 
+0

使用,仍然無法正常工作。謝謝你的信息。我在error.printStackTrace()中得到了以下錯誤com.google.gson.stream.MalformedJsonException:使用JsonReader.setLenient(true)在第2行第2列路徑中接受格式錯誤的JSON $ – Bruno