Android Volley Double Post
Это работает дважды; Это должно работать только один раз. Я пробовал с
_urlWebService = vars.ipServer.concat("/ws/disponibilidadTicket");
JsonObjectRequest jsonObjReq = new JsonObjectRequest(Request.Method.GET, _urlWebService, null,
new Response.Listener<JSONObject>()
{
@Override
public void onResponse(JSONObject response)
{
try
{
JSONArray clientes;
if(response.getBoolean("status"))
{
}
}
catch (JSONException e)
{
e.printStackTrace();
}
}
},
new Response.ErrorListener()
{
@Override
public void onErrorResponse(VolleyError error)
{
if (error instanceof TimeoutError)
{
AlertDialog.Builder builder = new AlertDialog.Builder(getApplicationContext());
builder
.setMessage("Error de conexión, sin respuesta del servidor.")
.setPositiveButton("Aceptar", new DialogInterface.OnClickListener()
{
@Override
public void onClick(DialogInterface dialog, int id)
{
}
}).show();
}
else
if (error instanceof NoConnectionError)
{
AlertDialog.Builder builder = new AlertDialog.Builder(getApplicationContext());
builder
.setMessage("Por favor, conectese a la red.")
.setPositiveButton("Aceptar", new DialogInterface.OnClickListener()
{
@Override
public void onClick(DialogInterface dialog, int id)
{
}
}).show();
}
else
if (error instanceof AuthFailureError)
{
AlertDialog.Builder builder = new AlertDialog.Builder(getApplicationContext());
builder
.setMessage("Error de autentificación en la red, favor contacte a su proveedor de servicios.")
.setPositiveButton("Aceptar", new DialogInterface.OnClickListener()
{
@Override
public void onClick(DialogInterface dialog, int id)
{
}
}).show();
}
else
if (error instanceof ServerError)
{
AlertDialog.Builder builder = new AlertDialog.Builder(getApplicationContext());
builder
.setMessage("Error server, sin respuesta del servidor.")
.setPositiveButton("Aceptar", new DialogInterface.OnClickListener()
{
@Override
public void onClick(DialogInterface dialog, int id)
{
}
}).show();
}
else
if (error instanceof NetworkError)
{
AlertDialog.Builder builder = new AlertDialog.Builder(getApplicationContext());
builder
.setMessage("Error de red, contacte a su proveedor de servicios.")
.setPositiveButton("Aceptar", new DialogInterface.OnClickListener()
{
@Override
public void onClick(DialogInterface dialog, int id)
{
}
}).show();
}
else
if (error instanceof ParseError)
{
AlertDialog.Builder builder = new AlertDialog.Builder(getApplicationContext());
builder
.setMessage("Error de conversión Parser, contacte a su proveedor de servicios.")
.setPositiveButton("Aceptar", new DialogInterface.OnClickListener()
{
@Override
public void onClick(DialogInterface dialog, int id)
{
}
}).show();
}
}
})
{
@Override
public Map<String, String> getHeaders() throws AuthFailureError
{
HashMap<String, String> headers = new HashMap <String, String>();
headers.put("Content-Type", "application/json; charset=utf-8");
headers.put("WWW-Authenticate", "xBasic realm=".concat(""));
headers.put("MyToken",sharedPreferences.getString("MyTokenAPI"));
return headers;
}
};
ControllerSingleton.getInstance().addToReqQueue(jsonObjReq, "");
jsonObjReq.setRetryPolicy(new DefaultRetryPolicy(20000, 1, DefaultRetryPolicy.DEFAULT_BACKOFF_MULT));
}
и все же он работает дважды. Кто-то знает, как решить эту проблему, поскольку она должна выполняться только один раз.
1 ответ
Вместо отправки 1 в retryPolicy попробуйте передать -1 и покажите, что ваш код вызывается только один раз. Примерно так:-
jsonObjReq.setRetryPolicy(new DefaultRetryPolicy(20000, -1, DefaultRetryPolicy.DEFAULT_BACKOFF_MULT));
Надеюсь, это решит вашу проблему.