1 回答

TA貢獻1827條經驗 獲得超9個贊
您可以使用ODataQueryBuilder執行任意 OData 調用,然后手動處理結果。
ODataQueryResult result = ODataQueryBuilder
? ? ? ? ? ? .withEntity("/base/path/to/api" + userPath, userEntity)
? ? ? ? ? ? .build()
? ? ? ? ? ? .execute("MyDestination");
然后如何處理結果在很大程度上取決于您的用例。如果返回的數據是您可以在運行時確定的已知類型,您可以簡單地檢索該類型的結果。在這個例子中,我們收到了一個項目列表:
List<MyClass> resList = result.asList(MyClass.class);
如果沒有,您可以處理ResultElement請求的 s,例如處理 json 對象:
result.getResultElements().forEach(e -> {
? ? ? ? if( e.isResultObject() ) {
? ? ? ? ? ? JsonObject obj = ((GsonResultObject)e).getJsonObject();
? ? ? ? ? ? // do some json processing
? ? ? ? }
? ? ? ? else if( e.isResultCollection() ) {
? ? ? ? ? ? // do something else
? ? ? ? }
? ? ? ? else {
? ? ? ? ? ? System.out.println(e.getAsPrimitive());
? ? ? ? }
? ? });
添加回答
舉報