Vin*_*rdo 1 android network-programming android-volley
我想将我的应用程序超时持续时间设置为60秒,这意味着我的应用程序只会解除ProgressDialog,如果它正在从服务器获得回复或它达到超时而不从服务器获得回复.
目前我正在使用Android上的Volley库,所以这就是我所做的:
private void loginOnline(final String user, final String pwd, final String login_url){
final ProgressDialog pd = new ProgressDialog(this);
pd.setMessage("Communicating with Server");
pd.show();
final RequestQueue queue = Volley.newRequestQueue(this);
Map<String, String> params = new HashMap<String, String>();
params.put(KEY_USERNAME, user);
params.put(KEY_PASSWORD, pwd);
final JsonObjectRequest jsonObjReq = new JsonObjectRequest(Request.Method.POST, login_url, new JSONObject(params),
new Response.Listener<JSONObject>() {
@Override
public void onResponse(JSONObject response) {
pd.dismiss();
try {
int msg = response.getInt("status");
sendMessage(msg);
}
catch (JSONException e){
e.printStackTrace();
}
}
}, new Response.ErrorListener() {
@Override
public void onErrorResponse(VolleyError error) {
pd.dismiss();
Log.d("D", "onErrorResponse: "+error.getMessage());
}
});
jsonObjReq.setRetryPolicy(new DefaultRetryPolicy(60000,0,DefaultRetryPolicy.DEFAULT_BACKOFF_MULT));
queue.add(jsonObjReq);
}
Run Code Online (Sandbox Code Playgroud)
问题是当我尝试连接到我的服务器时,它显示在日志中:
D/D: onErrorResponse: java.net.ConnectException: failed to connect to /192.123.x.xxx (port 3000) after 60000ms: isConnected failed: EHOSTUNREACH (No route to host)
D/Volley: [1] Request.finish: 3072 ms: [ ] http://192.123.4.215:3000/login 0xdde27c7c NORMAL 1
Run Code Online (Sandbox Code Playgroud)
我的问题是为什么它在达到60000ms之前停止连接到服务器.提前致谢
因为它不仅无法连接到主机 - 它无法找到到它的路由.这意味着它永远不会与主持人交谈.因此,它立即返回.重试策略正在运行,但仅在可能的情况下才适用.如果服务器拒绝连接或其他一些条件,它也会立即结束.
| 归档时间: |
|
| 查看次数: |
815 次 |
| 最近记录: |