改造通用响应处理程序
Retrofit generic response handler
我希望用一种方法处理我所有的回复。目的是当response code不为3时召回服务,当response code为3时我打算先刷新token再召回同一个服务。
我创建了一个Basecallback
class来捕获一个方法,但是我看不到日志,也无法捕获断点。
BASECALLBACK.class
public class BaseCallBack<T> implements Callback<T> {
@Override
public void onResponse(Call<T> call, Response<T> response) {
if (!response.isSuccessful()){
Log.d("BaseCallback","Response Fail");
}
}
@Override
public void onFailure(Call<T> call, Throwable t) {
t.toString();
}
}
调用方法
ApiManager.getInstance().getUsers().enqueue(new BaseCallBack<List<User>>() {
@Override
public void onResponse(Call<List<User>> call, Response<List<User>> response) {
if (response.isSuccessful()){
}
}
@Override
public void onFailure(Call<List<User>> call, Throwable t) {
}
});
我只想用单一方法处理我的服务。
你的起点很好 - 你有一个 ApiManager
这是你正在寻找的单一点 - class
,而不是 method
(方法不应该是在这种情况下只有一个接触点,它会使您的代码不可读并且以后更难调试。
从这里开始,使用您自己的自定义界面可能会更好,并根据您的意愿从调用请求的地方实现它,在那里您可以处理您想要的东西,这是 非常通用 示例,应该可以解决一些问题并让您继续前进。
请注意,这仍然需要您工作 - 调整并添加您需要的内容。
这就是你所需要的界面(非常基本,你可以添加东西)
public interface CustomCallListener<T>
{
public void getResult(T object);
}
这就是您应该如何在 ApiManager 中使用它 - 它接收您的接口作为携带预期 object 类型的参数,当响应 return 执行您需要的操作时 - 解析它,将它剪切,无论如何 - 并将其转换为正确的 object,此示例使用字符串响应和列表 return object,您可以期待任何您的想法并相应地解析它,Retrofit2 允许你直接解析 JSON 字符串(使用 GSON 或其他一些库),所以你决定在这里使用什么 - 如果你不明白我的意思 - 阅读它。
这也是我要添加断点和 Log.
调用以调试您收到的响应的地方,您还可以将 rawResponse
分解为 headers 和其他内容。
class ApiManager
{
// .. other stuff you need...
public void getSomeList(final CustomCallListener<List<SomeObject>> listener)
{
Call<ResponseBody> request = serviceCaller.getSomeInfo(userid);
//...other stuff you might need...
request.enqueue(new Callback<ResponseBody>()
{
@Override
public void onResponse(Call<ResponseBody> call, retrofit2.Response<ResponseBody> rawResponse)
{
try
{
String response = rawResponse.body().string();
//...other stuff you might need...
//...do something with the response, convert it to
//return the correct object...
SomeObject object = new SomeObject(response);
listener.getResult(object);
}
catch (Exception e)
{
// .. the response was no good...
listener.getResult(null);
}
}
@Override
public void onFailure(Call<ResponseBody> call, Throwable throwable)
{
// .. the response was no good...
listener.getResult(null);
}
});
}
}
最后,这是您应该在代码中的任何位置使用的内容 - 这允许您在那里实施回调并通过 ApiManager
中的 return 处理您需要的任何内容。
ApiManager.getInstance().getSomeList(new CustomCallListener<List<SomeObject>>()
{
@Override
public void getResult(List<SomeObject> objects)
{
if (null != objects)
{
// check objects and do whatever...
}
else
{
// ... do other stuff .. handle failure codes etc.
}
}
});
注意事项
如前所述 - 这是一个非常通用的框架,可以进行很大的修改(向具有不同 return 类型的接口添加更多方法来处理异常、错误响应、其他 objects,添加更多参数到同一方法以处理更多选项等)更多地了解该主题,注意传递 null Objects,使用 try 和 catches 避免崩溃。
希望对您有所帮助!
我希望用一种方法处理我所有的回复。目的是当response code不为3时召回服务,当response code为3时我打算先刷新token再召回同一个服务。
我创建了一个Basecallback
class来捕获一个方法,但是我看不到日志,也无法捕获断点。
BASECALLBACK.class
public class BaseCallBack<T> implements Callback<T> {
@Override
public void onResponse(Call<T> call, Response<T> response) {
if (!response.isSuccessful()){
Log.d("BaseCallback","Response Fail");
}
}
@Override
public void onFailure(Call<T> call, Throwable t) {
t.toString();
}
}
调用方法
ApiManager.getInstance().getUsers().enqueue(new BaseCallBack<List<User>>() {
@Override
public void onResponse(Call<List<User>> call, Response<List<User>> response) {
if (response.isSuccessful()){
}
}
@Override
public void onFailure(Call<List<User>> call, Throwable t) {
}
});
我只想用单一方法处理我的服务。
你的起点很好 - 你有一个 ApiManager
这是你正在寻找的单一点 - class
,而不是 method
(方法不应该是在这种情况下只有一个接触点,它会使您的代码不可读并且以后更难调试。
从这里开始,使用您自己的自定义界面可能会更好,并根据您的意愿从调用请求的地方实现它,在那里您可以处理您想要的东西,这是 非常通用 示例,应该可以解决一些问题并让您继续前进。
请注意,这仍然需要您工作 - 调整并添加您需要的内容。
这就是你所需要的界面(非常基本,你可以添加东西)
public interface CustomCallListener<T>
{
public void getResult(T object);
}
这就是您应该如何在 ApiManager 中使用它 - 它接收您的接口作为携带预期 object 类型的参数,当响应 return 执行您需要的操作时 - 解析它,将它剪切,无论如何 - 并将其转换为正确的 object,此示例使用字符串响应和列表 return object,您可以期待任何您的想法并相应地解析它,Retrofit2 允许你直接解析 JSON 字符串(使用 GSON 或其他一些库),所以你决定在这里使用什么 - 如果你不明白我的意思 - 阅读它。
这也是我要添加断点和 Log.
调用以调试您收到的响应的地方,您还可以将 rawResponse
分解为 headers 和其他内容。
class ApiManager
{
// .. other stuff you need...
public void getSomeList(final CustomCallListener<List<SomeObject>> listener)
{
Call<ResponseBody> request = serviceCaller.getSomeInfo(userid);
//...other stuff you might need...
request.enqueue(new Callback<ResponseBody>()
{
@Override
public void onResponse(Call<ResponseBody> call, retrofit2.Response<ResponseBody> rawResponse)
{
try
{
String response = rawResponse.body().string();
//...other stuff you might need...
//...do something with the response, convert it to
//return the correct object...
SomeObject object = new SomeObject(response);
listener.getResult(object);
}
catch (Exception e)
{
// .. the response was no good...
listener.getResult(null);
}
}
@Override
public void onFailure(Call<ResponseBody> call, Throwable throwable)
{
// .. the response was no good...
listener.getResult(null);
}
});
}
}
最后,这是您应该在代码中的任何位置使用的内容 - 这允许您在那里实施回调并通过 ApiManager
中的 return 处理您需要的任何内容。
ApiManager.getInstance().getSomeList(new CustomCallListener<List<SomeObject>>()
{
@Override
public void getResult(List<SomeObject> objects)
{
if (null != objects)
{
// check objects and do whatever...
}
else
{
// ... do other stuff .. handle failure codes etc.
}
}
});
注意事项
如前所述 - 这是一个非常通用的框架,可以进行很大的修改(向具有不同 return 类型的接口添加更多方法来处理异常、错误响应、其他 objects,添加更多参数到同一方法以处理更多选项等)更多地了解该主题,注意传递 null Objects,使用 try 和 catches 避免崩溃。
希望对您有所帮助!