根据Volley的响应代码Android将用户重定向到特定活动

如何解决根据Volley的响应代码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。

任何帮助将不胜感激。

非常感谢您。

祝你有美好的一天。

编辑:用于调用上述类的代码

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");
}}

解决方法

因此,我发现了一个修复程序,虽然有些乏味但很简单。 基本上,我必须重写liverError方法。在该方法中,存在errorCode,因此基于该代码,我能够执行重定向。 还需要在构造函数中传递上下文。需要在所有请求调用中进行更改。

根据我的理解,此方法起作用的原因是,当工作线程需要尝试合并回主UI线程时会调用liverError。这种分支是在parseNetworkResponse中引起的,因为这是一个繁重的过程,这就是为其分配工作线程的原因。

更新的班级:

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;
    }
}

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其他元素将获得点击?
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。)
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbcDriver发生异常。为什么?
这是用Java进行XML解析的最佳库。
Java的PriorityQueue的内置迭代器不会以任何特定顺序遍历数据结构。为什么?
如何在Java中聆听按键时移动图像。
Java“Program to an interface”。这是什么意思?
Java在半透明框架/面板/组件上重新绘画。
Java“ Class.forName()”和“ Class.forName()。newInstance()”之间有什么区别?
在此环境中不提供编译器。也许是在JRE而不是JDK上运行?
Java用相同的方法在一个类中实现两个接口。哪种接口方法被覆盖?
Java 什么是Runtime.getRuntime()。totalMemory()和freeMemory()?
java.library.path中的java.lang.UnsatisfiedLinkError否*****。dll
JavaFX“位置是必需的。” 即使在同一包装中
Java 导入两个具有相同名称的类。怎么处理?
Java 是否应该在HttpServletResponse.getOutputStream()/。getWriter()上调用.close()?
Java RegEx元字符(。)和普通点?