- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
这里有人知道如何对 Django Rest Framework 项目进行改造吗?我已经按照记录在两端完成了我需要做的一切,它返回了我在 http://www.jsonschema2pojo.org/ 上生成 Pojos 的有效 Json。 ,但出于某种奇怪的原因,Retrofit 不断从给出的 Json 结果中返回一个空列表,我需要它才能生效,所以我明天向我的主管演示我的工作。请帮忙P.S:toast 中的所有内容都显示 0 值、我的 storePlaces arraylist 从中获取数据的列表的大小、storePlaces Arraylist 本身以及 Retrofit 返回的状态代码。希望有用这是我的代码:
API 端点:
// Request method and URL specified in the annotation
// Callback for the parsed response is the last parameter
@GET("/api/products/")
Call<List<Store>> getStoreList(@Query("format") String format);
@GET("/api/stores/{store_id}/")
Call<Store> getClickedStore(@Path("store_id") Integer store_id, @Query("format") String format);
POJO:
public class Store extends RealmObject {
@SerializedName("id")
@Expose
private int id;
@SerializedName("name")
@Expose
private String name;
@SerializedName("picture")
@Expose
private String picture;
@SerializedName("Phone")
@Expose
private String Phone;
@SerializedName("email")
@Expose
private String email;
@SerializedName("website")
@Expose
private String website;
@SerializedName("longitude")
@Expose
private String longitude;
@SerializedName("latitude")
@Expose
private String latitude;
@SerializedName("address")
@Expose
private String address;
/**
*
* @return
* The id
*/
public int getId() {
return id;
}
/**
*
* @param id
* The id
*/
public void setId(int id) {
this.id = id;
}
/**
*
* @return
* The name
*/
public String getName() {
return name;
}
/**
*
* @param name
* The name
*/
public void setName(String name) {
this.name = name;
}
/**
*
* @return
* The picture
*/
public String getPicture() {
return picture;
}
/**
*
* @param picture
* The picture
*/
public void setPicture(String picture) {
this.picture = picture;
}
/**
*
* @return
* The Phone
*/
public String getPhone() {
return Phone;
}
/**
*
* @param Phone
* The Phone
*/
public void setPhone(String Phone) {
this.Phone = Phone;
}
/**
*
* @return
* The email
*/
public String getEmail() {
return email;
}
/**
*
* @param email
* The email
*/
public void setEmail(String email) {
this.email = email;
}
/**
*
* @return
* The website
*/
public String getWebsite() {
return website;
}
/**
*
* @param website
* The website
*/
public void setWebsite(String website) {
this.website = website;
}
/**
*
* @return
* The longitude
*/
public String getLongitude() {
return longitude;
}
/**
*
* @param longitude
* The longitude
*/
public void setLongitude(String longitude) {
this.longitude = longitude;
}
/**
*
* @return
* The latitude
*/
public String getLatitude() {
return latitude;
}
/**
*
* @param latitude
* The latitude
*/
public void setLatitude(String latitude) {
this.latitude = latitude;
}
/**
*
* @return
* The address
*/
public String getAddress() {
return address;
}
/**
*
* @param address
* The address
*/
public void setAddress(String address) {
this.address = address;
}
}
调用Retrofit的方法:
private ArrayList<Store> getDataSet() {
Gson gson = new GsonBuilder()
.setExclusionStrategies(new ExclusionStrategy() {
@Override
public boolean shouldSkipField(FieldAttributes f) {
return f.getDeclaringClass().equals(RealmObject.class);
}
@Override
public boolean shouldSkipClass(Class<?> clazz) {
return false;
}
})
.create();
Retrofit retrofitClient = new Retrofit.Builder()
.baseUrl(BASE_URL)
.addConverterFactory(GsonConverterFactory.create(gson))
.build();
// create a new service call variable from the interface with retrofitClient
ShoplistApiEndpointInterface apiService = retrofitClient.create(ShoplistApiEndpointInterface.class);
//create a new APICall variable of the api interface with its type being that of the call method you'll invoke from the interface
Call<List<Store>> storeListCall = apiService.getStoreList(FORMAT_SPECIFIER);
// make the call asynchronously by calling enqueue on the Call type
//FIXME: chane serverside encoding is option 1 (type:app/json, encoding: utf8)
storeListCall.enqueue(new Callback<List<Store>>() {
@Override
public void onResponse(Call<List<Store>> call, Response<List<Store>> response) {
// get status code from the HTTP response code
statusCode = response.code();
// add the parsed response body data (parsed pojo object list in this case)
// to the arrayList with the addAll(Collection<type>) method
List<Store> results = response.body();
ressize = response.body().size();
int initialSize = storePlaces.size();
storePlaces.addAll(initialSize, results);
}
@Override
public void onFailure(Call<List<Store>> call, Throwable t) {
// log the error here
Log.e(LOG_TAG, "Failed to download Place list", t);
Toast.makeText(getActivity(), R.string.failed_to_download_list, Toast.LENGTH_SHORT).show();
}
});
Log.d(LOG_TAG, "Success, new data set is of size " + storePlaces.size() + " with status code: " + statusCode + " from source sized: " + ressize);
return storePlaces;
}
JSON(从那以后我更新了它以限制用户对他们没有创建的对象具有超过只读的访问权限,所以所有者部分是一个新事物..但是 chrome 的 JSONview 扩展验证了第一个和这个JSON 版本)
[
{
id: 1,
name: "Shoprite Zm",
picture: "http://127.0.0.1:8000/api/stores/productphotos/stores/serializer_snPGr8P.PNG",
Phone: "0255447854",
email: "fabf@ducj.omf",
website: "http://www.f.rd",
latitude: "0.000000",
longitude: "0.000000",
address: "noiibuiuwefd",
owner: 1
},
{
id: 2,
name: "Game fr",
picture: "http://127.0.0.1:8000/api/stores/productphotos/stores/orcl.PNG",
Phone: "467565",
email: "fnini@irni.nur",
website: "http://afninni.gg.rtd",
latitude: "0.000000",
longitude: "0.000000",
address: "horvsawhgfl,md boisdrl",
owner: 1
},
{
id: 3,
name: "Ret",
picture: null,
Phone: "ajiwenpgoernen",
email: "fihIANPI@FNIIW.VID",
website: "http://FWIHFIFNVOI.fnawifni.afvn9weo.FNWIA",
latitude: "0.000000",
longitude: "0.000000",
address: "fawzsuvba.wfQSFBON",
owner: 1
}
]
(Django 开发服务器控制台输出的最后几个请求是针对我的应用程序的,其余的来自浏览器)
最佳答案
您不能从方法返回异步回调的结果。当方法返回时,您的 storePlaces
始终为空,因为 Retrofit http 调用尚未完成。
解决这个问题的方法是将您自己的回调方法作为 getDataSet()
方法的参数传递。首先定义一个通用的回调接口(interface):
public interface Callback<T> {
void next(T result);
}
然后更改您的 getDataSet()
方法:
public void getDataSet(Callback<List<Store>> callback) {
//...
@Override
public void onResponse(Call<List<Store>> call, Response<List<Store>> response) {
// get status code from the HTTP response code
statusCode = response.code();
// add the parsed response body data (parsed pojo object list in this case)
// to the arrayList with the addAll(Collection<type>) method
List<Store> results = response.body();
ressize = response.body().size();
int initialSize = storePlaces.size();
storePlaces.addAll(initialSize, results);
callback.next(storePlaces);
}
//...
}
现在在您使用 getDataSet
方法的代码中,您可以这样调用它:
getDataSet(new Callback<List<Store>>() {
@Override
public void next(List<Store> results) {
// use the results
}
}
)
编辑 简要说明
这是观察者模式的一个例子。
您向Subject
(您的Retrofit 运行方法)注册了一个Observer
(Callback 接口(interface)的具体实现)。当 Subject
完成它所做的任何任务时,它会通知 Observer
然后运行它的代码。
您可以在需要从中获取结果的异步操作发生的情况下使用此模式。它还在整个 Android 框架中用于注册监听器,例如 OnClickListener。
关于android - Retrofit 返回空数组列表,但给出了有效的 POJO 和 Json 来处理(尝试了其他问题,但对它们起作用的答案不在 mne 上),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/36675222/
最近开始学习MongoDB。今天老师教了我们 mongoexport 命令。在练习时,我遇到了一个典型的问题,包括教练在内的其他同学都没有遇到过。我在我的 Windows 10 机器上使用 Mongo
我是 JSON Schema 的新手,读过什么是 JSON Schema 等等。但我不知道如何将 JSON Schema 链接到 JSON 以针对该 JSON Schema 进行验证。谁能解释一下?
在 xml 中,我可以在另一个 xml 文件中包含一个文件并使用它。如果您的软件从 xml 获取配置文件但没有任何方法来分离配置,如 apache/ngnix(nginx.conf - site-av
我有一个 JSON 对象,其中包含一个本身是 JSON 对象的字符串。我如何反序列化它? 我希望能够做类似的事情: #[derive(Deserialize)] struct B { c: S
考虑以下 JSON { "a": "{\"b\": 12, \"c\": \"test\"}" } 我想定义一个泛型读取 Reads[Outer[T]]对于这种序列化的 Json import
关闭。这个问题不满足Stack Overflow guidelines .它目前不接受答案。 想改善这个问题吗?更新问题,使其成为 on-topic对于堆栈溢出。 11 个月前关闭。 Improve
我的旧项目在 MySQL 中有 Standard JSON 格式的数据。 对于我在 JS (Node.js) 和 DynamoDB 中的全新项目,关于 Standard JSON格式: 是否建议将其转
JSON 值字符串、数字、true、false、null 是否是有效的 JSON? 即,是 true 一个有效的 JSON 文档?还是必须是数组/对象? 一些验证器接受这个(例如 http://jso
我有一个 JSON 字符串,其中一个字段是文本字段。这个文本字段可以包含用户在 UI 中输入的文本,如果他们输入的文本是 JSON 文本,也许是为了说明一些编码,我需要对他们的文本进行编码,以便它不会
我正在通过 IBM MQ 调用处理数据,当由 ColdFusion 10 (10,0,11,285437) 序列化时,0 将作为 +0.0 返回,它会导致无效的 JSON并且无法反序列化。 stPol
我正在从三个数组中生成一个散列,然后尝试构建一个 json。我通过 json object has array 成功了。 require 'json' A = [['A1', 'A2', 'A3'],
我从 API 接收 JSON,响应可以是 30 种类型之一。每种类型都有一组唯一的字段,但所有响应都有一个字段 type 说明它是哪种类型。 我的方法是使用serde .我为每种响应类型创建一个结构并
我正在下载一个 JSON 文件,我已将其检查为带有“https://jsonlint.com”的有效 JSON 到文档目录。然后我打开文件并再次检查,结果显示为无效的 JSON。这怎么可能????这是
我正在尝试根据从 API 接收到的数据动态创建一个 JSON 对象。 收到的示例数据:将数据解码到下面给出的 CiItems 结构中 { "class_name": "test", "
我想从字符串转换为对象。 来自 {"key1": "{\n \"key2\": \"value2\",\n \"key3\": {\n \"key4\": \"value4\"\n }\n
目前我正在使用以下代码将嵌套的 json 转换为扁平化的 json: import ( "fmt" "github.com/nytlabs/gojsonexplode" ) func
我有一个使用来自第三方 API 的数据的应用程序。我需要将 json 解码为一个结构,这需要该结构具有“传入”json 字段的 json 标签。传出的 json 字段具有不同的命名约定,因此我需要不同
我想使用 JSON 架构来验证某些值。我有两个对象,称它们为 trackedItems 和 trackedItemGroups。 trackedItemGroups 是组名称和 trackedItem
考虑以下案例类模式, case class Y (a: String, b: String) case class X (dummy: String, b: Y) 字段b是可选的,我的一些数据集没有字
我正在存储 cat ~/path/to/file/blah | 的输出jq tojson 在一个变量中,稍后在带有 JSON 内容的 curl POST 中使用。它运作良好,但它删除了所有换行符。我知
我是一名优秀的程序员,十分优秀!