我正在尝试使用自定义转换器进行改造
RestAdapter.Builder builder = new RestAdapter.Builder()
.setEndpoint(BuildConfig.BASE_SERVER_ENDPOINT)
.setClient(new OkClient(client)).setConverter(new CitationResponseConverter())
.setLogLevel(RestAdapter.LogLevel.FULL);
以下是我的自定义转换器
public class CitationResponseConverter implements Converter {
@Override
public Object fromBody(TypedInput typedInput, Type type) throws ConversionException {
try {
InputStream in = typedInput.in(); // convert the typedInput to String
String string = fromStream(in);
in.close(); // we are responsible to close the InputStream after use
if (String.class.equals(type)) {
return string;
} else {
return new Gson().fromJson(string,
type); // convert to the supplied type, typically Object, JsonObject or Map<String, Object>
}
} catch (Exception e) { // a lot may happen here, whatever happens
throw new ConversionException(
e); // wrap it into ConversionException so retrofit can process it
}
}
@Override
public TypedOutput toBody(Object object) {
return null;
}
private static String fromStream(InputStream in) throws IOException {
BufferedReader reader = new BufferedReader(new InputStreamReader(in));
StringBuilder out = new StringBuilder();
String line;
while ((line = reader.readLine()) != null) {
out.append(line);
out.append("\r\n");
}
return out.toString();
}
}
我收到以下错误
retrofit.RetrofitError: method POST must have a request body.
在尝试进行此api调用时
@POST("/service/citations")
Observable<CitationMain> getCitations(@Body CitationRequestBody body);
我想转换器正在覆盖对api调用的请求,如何避免这种情况并传递在改造服务中定义的请求主体。
回应:
{
"citations": [
{
"coverdatestart": "2015-05-01",
"coverimage": [
"09699961/S0969996115X00040/cov200h.gif",
"09699961/S0969996115X00040/cov150h.gif"
],
"pubyear": "2015",
"refimage": [
"09699961/S0969996115X00040/S0969996115000522/gr1-t.gif",
"09699961/S0969996115X00040/S0969996115000522/gr1.jpg"
],
"volissue": "Volume 77",
"volume": "77"
},
{
"pubdatetxt": "19700101",
"refimage": "mma:otto_4_9781455748600/9781455748600_0020",
}
]
}
我会做这样的事情:
public class StringList extends ArrayList<String> {
// Empty on purpose. The class is here only to be recognized by Gson
}
public class CitationMain {
@SerializedName("field_name_here")
StringList values;
// Your other fields
}
然后在创建RestAdapter时:
public class StringListDeserializer implements JsonDeserializer<StringList> {
@Override
public StringList deserialize(JsonElement json, Type typeOfT, JsonDeserializationContext
context) throws JsonParseException {
StringList value = new StringList();
if (json.isJsonArray()) {
for (JsonElement element : json.getAsJsonArray()) {
value.add(element.getAsString());
}
} else {
value.add(json.getAsString());
}
return value;
}
}
然后:
Gson gson = new GsonBuilder()
.registerTypeAdapter(StringList.class, new StringListDeserializer())
.create();
RestAdapter.Builder builder = new RestAdapter.Builder()
//...
.setConverter(new GsonConverter(gson));
这不是理想的,因为对象是自定义的,但是我现在能想到的任何其他解决方案都更加复杂。
这里的反序列化器专门为声明为的字段注册StringList
,将处理单个字符串的情况以及字符串数组的情况。任何其他字段类型将使用默认的反序列化过程。
如何将自定义转换器添加到mu Spring Boot应用程序?我的实体字段 我的转换器是 我有个例外 我怎样才能修好它,请帮帮我!
题目描述 将十进制整数n转换成k进制数。 输入格式: 首先输入一个整数T,表示测试数据的组数,然后是T组测试数据。每组测试数据输入两个整数n和k( -1000000 ≤ n ≤ 1000000,> 2 ≤ k ≤ 9)。 输出格式: 对于每组测试,先输出n, 然后输出一个空格,最后输出对应的k进制数。 输入样例: 2 123 8 -12 2 输出样例: 123 173 -12 -1100 解题代码
我们可以在JSF中创建自己的自定义转换器。 在JSF中定义自定义转换器分为三个步骤。 步 描述 1 通过实现javax.faces.convert.Converter接口创建转换器类。 2 实现上面接口的getAsObject()和getAsString()方法。 3 使用注释@FacesConvertor为自定义转换器分配唯一的ID。 第1步:创建转换器类:UrlConverter.java p
XStream允许从头开始编写转换器,以便开发人员可以编写一个全新的实现,介绍如何将对象序列化为XML,反之亦然。 转换器接口提供三种方法 - canConvert - 检查支持的对象类型序列化。 marshal - 它将对象序列化为XML。 unmarshal - 它从XML unmarshal序列化对象。 第1步:实现转换器接口 class StudentConverter implement
本文向大家介绍十进制到二进制转换,包括了十进制到二进制转换的使用技巧和注意事项,需要的朋友参考一下 十进制数字也可以转换为二进制格式。要将十进制数转换为二进制数,我们需要将数字除以2,直到达到0或1。然后,在每一步骤中,其余部分将分开存储以形成相反的二进制等效数。 在此算法中,我们将遵循递归方法。这将帮助我们在不使用堆栈数据结构的情况下解决问题。在实现中,我们知道函数的递归将遵循内部堆栈。我们将使
问题内容: 我有一个家庭作业,需要在十进制,二进制和十六进制之间进行三向转换。我需要帮助的功能是将十进制转换为十六进制。我几乎不了解十六进制,但是如何将十进制转换为十六进制。我需要一个接受并返回的函数。不幸的是我没有此功能的任何草稿,我完全迷路了。我只有这个。 另外,我不能使用诸如Integer.toHexString()之类的预制函数或任何其他东西,我需要真正地制作算法,否则我什么都不会学。 问