根据 Volley 的响应代码 (Android) 将用户重定向到某个 activity
Redirect User to a certain activity based on Volley's response code (Android)
我正在尝试根据服务器的响应代码启动一个 Intent。
所有请求都使用 Volley 执行。以下是我正在使用的自定义请求:
public class JSONObjectRequestUTF8 extends JsonObjectRequest {
public JSONObjectRequestUTF8(int method, String url, JSONObject jsonRequest,
Listener<JSONObject> listener, ErrorListener errorListener) {
super(method, url, jsonRequest, listener,
errorListener);
setShouldCache(false);
}
@Override
protected Response<JSONObject> parseNetworkResponse (NetworkResponse response) {
try {
String utf8String = new String(response.data, "UTF-8");
return Response.success(new JSONObject(utf8String), HttpHeaderParser.parseCacheHeaders(response));
} catch (UnsupportedEncodingException e) {
// log error
return Response.error(new ParseError(e));
} catch (JSONException e) {
// log error
return Response.error(new ParseError(e));
}
}
在 ParseNetworkResponse 中错误代码正确。但是我无法弄清楚如何从这里开始一个 Intent。
如有任何帮助,我们将不胜感激。
非常感谢您。
祝你有愉快的一天。
编辑:调用上述内容的代码class
public class AuditAPI implements Response.Listener<JSONObject>, Response.ErrorListener {
private Context mContext;
private SharedPreferences deviceInfo;
public void makeAudit(final Context mContent,String ipAddress, int status){
this.mContext = mContent;
final HashMap<String, String> login_model = SessionManager.getInstance().getUserDetails(mContent);
JsonObjectRequest jsonObjReq = new JSONObjectRequestUTF8(Request.Method.POST, Constants.MAKE_AUDIT , null, this, this){
@Override
public Map<String, String> getHeaders() throws AuthFailureError {
HashMap<String, String> headers = new HashMap<>();
headers.put(Constants.SUBJECTID,
login_model.get(Constants.SUBJECTID));
headers.put(Constants.ACCESSTOKEN,
login_model.get(Constants.ACCESSTOKEN));
headers.put("user-agent","Android");
headers.put("DEVICEID",Constants.DEVICE_ID);
headers.put("VAPPID", Constants.VAPP_ID);
headers.put("LOGIN_USER_NAME", (MyBaseActivity.getmUserId()));
headers.put("STATUS", String.valueOf(status));
headers.put("IPADDRESS",ipAddress);
headers.put("CONTENT_TYPE",Constants.JSON_FROMAT);
return headers;
}
};
jsonObjReq.setRetryPolicy(new DefaultRetryPolicy(1,
DefaultRetryPolicy.DEFAULT_MAX_RETRIES, DefaultRetryPolicy.DEFAULT_BACKOFF_MULT));
MyApplicationController.getNewInstance(mContext).
addToRequestQueue(jsonObjReq, "AUDIT");
}
@Override
public void onErrorResponse(VolleyError volleyError) {
Log.i("Failure", "onErrorResponse: ");
}
@Override
public void onResponse(JSONObject jsonObject) {
Log.i("Success","onResponse Audit");
}}
所以我找到了一个有点繁琐但简单的修复程序。
基本上我必须重写 deliverError 方法。在该方法中存在 errorCode,因此基于该代码我能够执行重定向。
还需要在构造函数中传递上下文。需要在所有请求调用中进行更改。
根据我的理解,这样做的原因是当工作线程需要尝试合并回主 UI 线程时调用 deliverError。此分叉是在 parseNetworkResponse 中引起的,因为它是一个繁重的进程,这就是为什么要为其分配工作线程的原因。
已更新Class:
public class JSONObjectRequestUTF8 extends JsonObjectRequest {
//This is a new parameter
private Context context;
public JSONObjectRequestUTF8(int method, String url, JSONObject jsonRequest,
Listener<JSONObject> listener, ErrorListener errorListener,Context context) {
super(method, url, jsonRequest, listener,
errorListener);
this.context = context;
setShouldCache(false);
}
@Override
protected Response<JSONObject> parseNetworkResponse (NetworkResponse response) {
try {
String utf8String = new String(response.data, "UTF-8");
return Response.success(new JSONObject(utf8String), HttpHeaderParser.parseCacheHeaders(response));
} catch (UnsupportedEncodingException e) {
// log error
return Response.error(new ParseError(e));
} catch (JSONException e) {
// log error
return Response.error(new ParseError(e));
}
}
@Override
public void deliverError(VolleyError error) {
if(error.networkResponse.statusCode == HttpURLConnection.HTTP_PRECON_FAILED || error.networkResponse.statusCode == HttpURLConnection.HTTP_UNAUTHORIZED){
Intent i = new Intent(context, LoginActivity.class);
i.putExtra(EReceiptsConstants.ERROR_MESSAGE, EReceiptsConstants.SESSION_MESSAGE);
i.addFlags(Intent.FLAG_ACTIVITY_NEW_TASK);
i.addFlags(Intent.FLAG_ACTIVITY_CLEAR_TOP);
context.startActivity(i);
return;
}
}
我正在尝试根据服务器的响应代码启动一个 Intent。 所有请求都使用 Volley 执行。以下是我正在使用的自定义请求:
public class JSONObjectRequestUTF8 extends JsonObjectRequest {
public JSONObjectRequestUTF8(int method, String url, JSONObject jsonRequest,
Listener<JSONObject> listener, ErrorListener errorListener) {
super(method, url, jsonRequest, listener,
errorListener);
setShouldCache(false);
}
@Override
protected Response<JSONObject> parseNetworkResponse (NetworkResponse response) {
try {
String utf8String = new String(response.data, "UTF-8");
return Response.success(new JSONObject(utf8String), HttpHeaderParser.parseCacheHeaders(response));
} catch (UnsupportedEncodingException e) {
// log error
return Response.error(new ParseError(e));
} catch (JSONException e) {
// log error
return Response.error(new ParseError(e));
}
}
在 ParseNetworkResponse 中错误代码正确。但是我无法弄清楚如何从这里开始一个 Intent。
如有任何帮助,我们将不胜感激。
非常感谢您。
祝你有愉快的一天。
编辑:调用上述内容的代码class
public class AuditAPI implements Response.Listener<JSONObject>, Response.ErrorListener {
private Context mContext;
private SharedPreferences deviceInfo;
public void makeAudit(final Context mContent,String ipAddress, int status){
this.mContext = mContent;
final HashMap<String, String> login_model = SessionManager.getInstance().getUserDetails(mContent);
JsonObjectRequest jsonObjReq = new JSONObjectRequestUTF8(Request.Method.POST, Constants.MAKE_AUDIT , null, this, this){
@Override
public Map<String, String> getHeaders() throws AuthFailureError {
HashMap<String, String> headers = new HashMap<>();
headers.put(Constants.SUBJECTID,
login_model.get(Constants.SUBJECTID));
headers.put(Constants.ACCESSTOKEN,
login_model.get(Constants.ACCESSTOKEN));
headers.put("user-agent","Android");
headers.put("DEVICEID",Constants.DEVICE_ID);
headers.put("VAPPID", Constants.VAPP_ID);
headers.put("LOGIN_USER_NAME", (MyBaseActivity.getmUserId()));
headers.put("STATUS", String.valueOf(status));
headers.put("IPADDRESS",ipAddress);
headers.put("CONTENT_TYPE",Constants.JSON_FROMAT);
return headers;
}
};
jsonObjReq.setRetryPolicy(new DefaultRetryPolicy(1,
DefaultRetryPolicy.DEFAULT_MAX_RETRIES, DefaultRetryPolicy.DEFAULT_BACKOFF_MULT));
MyApplicationController.getNewInstance(mContext).
addToRequestQueue(jsonObjReq, "AUDIT");
}
@Override
public void onErrorResponse(VolleyError volleyError) {
Log.i("Failure", "onErrorResponse: ");
}
@Override
public void onResponse(JSONObject jsonObject) {
Log.i("Success","onResponse Audit");
}}
所以我找到了一个有点繁琐但简单的修复程序。 基本上我必须重写 deliverError 方法。在该方法中存在 errorCode,因此基于该代码我能够执行重定向。 还需要在构造函数中传递上下文。需要在所有请求调用中进行更改。
根据我的理解,这样做的原因是当工作线程需要尝试合并回主 UI 线程时调用 deliverError。此分叉是在 parseNetworkResponse 中引起的,因为它是一个繁重的进程,这就是为什么要为其分配工作线程的原因。
已更新Class:
public class JSONObjectRequestUTF8 extends JsonObjectRequest {
//This is a new parameter
private Context context;
public JSONObjectRequestUTF8(int method, String url, JSONObject jsonRequest,
Listener<JSONObject> listener, ErrorListener errorListener,Context context) {
super(method, url, jsonRequest, listener,
errorListener);
this.context = context;
setShouldCache(false);
}
@Override
protected Response<JSONObject> parseNetworkResponse (NetworkResponse response) {
try {
String utf8String = new String(response.data, "UTF-8");
return Response.success(new JSONObject(utf8String), HttpHeaderParser.parseCacheHeaders(response));
} catch (UnsupportedEncodingException e) {
// log error
return Response.error(new ParseError(e));
} catch (JSONException e) {
// log error
return Response.error(new ParseError(e));
}
}
@Override
public void deliverError(VolleyError error) {
if(error.networkResponse.statusCode == HttpURLConnection.HTTP_PRECON_FAILED || error.networkResponse.statusCode == HttpURLConnection.HTTP_UNAUTHORIZED){
Intent i = new Intent(context, LoginActivity.class);
i.putExtra(EReceiptsConstants.ERROR_MESSAGE, EReceiptsConstants.SESSION_MESSAGE);
i.addFlags(Intent.FLAG_ACTIVITY_NEW_TASK);
i.addFlags(Intent.FLAG_ACTIVITY_CLEAR_TOP);
context.startActivity(i);
return;
}
}