http协议中可以设置超时(连接超时、响应超时),具体设置情景如下:
1、java api的方式:
JDK 1.5以前的版本,只能通过设置两个系统属性来控制网络超时:
String szUrl = “http://www.ee2ee.com/”; URL url = new URL(szUrl); HttpURLConnection urlCon = (HttpURLConnection)url.openConnection(); //HttpURLConnection是基于HTTP协议的,其底层通过socket通信实现。如果不设置超时(timeout),在网络异常的情况下,可能会导致程序僵死而不继续往下执行。可以通过以下两个语句来设置相应的超时: System.setProperty(”sun.net.client.defaultConnectTimeout”, 超时毫秒数字符串); System.setProperty(”sun.net.client.defaultReadTimeout”, 超时毫秒数字符串); //sun.net.client.defaultConnectTimeout:连接主机的超时时间(单位:毫秒) //sun.net.client.defaultReadTimeout:从主机读取数据的超时时间(单位:毫秒)在1.5中,还可以使用HttpURLConnection的父类URLConnection的以下两个方法:
HttpURLConnection urlCon = (HttpURLConnection)url.openConnection(); urlCon.setConnectTimeout(30000); urlCon.setReadTimeout(30000);需要注意的是,笔者在JDK1.4.2环境下,发现在设置了 defaultReadTimeout的情况下,如果发生网络超时,HttpURLConnection会自动重新提交一次请求,出现一次请求调用,请求服务器两次的问题(Trouble)。我认为这是JDK1.4.2的一个bug。在JDK1.5.0中,此问题已得到解决,不存在自动重发现象。 out”, “30000″);
2、httpClient:
HttpClient工具类,每一个版本的都不一样:
3.X是这样的
HttpClient httpClient=new DefaultHttpClient();
4.3是这样的
CloseableHttpClient httpClient = HttpClients.createDefault();
HttpClient有三种超时设置:
1)3.X的超时设置方法
HttpClient client = new HttpClient();
client.setConnectionTimeout(30000);
client.setTimeout(30000);
HttpClient httpClient= new HttpClient();
httpClient.getHttpConnectionManager().getParams().setConnectionTimeout(5000);
2)4.X版本的超时设置(4.3后已过时)
HttpClient httpClient=new DefaultHttpClient();
httpClient.getParams().setParameter(CoreConnectionPNames.CONNECTION_TIMEOUT,2000);//连接时间
httpClient.getParams().setParameter(CoreConnectionPNames.SO_TIMEOUT,2000);//数据传输时间
3)4.3版本超时设置
CloseableHttpClient httpClient = HttpClients.createDefault();
HttpGet httpGet=new HttpGet("http://www.baidu.com");//HTTP Get请求(POST雷同)
RequestConfig requestConfig = RequestConfig.custom().setSocketTimeout(2000).setConnectTimeout(2000).build();//设置请求和传输超时时间
httpGet.setConfig(requestConfig);
httpClient.execute(httpGet);//执行请求
3、使用curl时,有两个超时时间:一个是连接超时时间,另一个是数据传输的最大允许时间。
连接超时时间用 --connect-timeout 参数来指定,数据传输的最大允许时间用 -m 参数来指定。
例如:
curl --connect-timeout 10 -m 20 "http://XXXXXXX"
连接超时的话,出错提示形如:
curl: (28) connect() timed out!
数据传输的最大允许时间超时的话,出错提示形如:
curl: (28) Operation timed out after 2000 milliseconds with 0 bytes received
4、ajax:
1)在xmlHttpRequest老版本中,没有超时属性,所以如果使用javascript原生的老版本ajax请求,只能通过手工设置settimeout和cleartimeout这两个方法完成(这两个方法是window对象的方法)
function createXMLHttpRequest() { var request = false; if (window.XMLHttpRequest) { request = new XMLHttpRequest(); if (request.overrideMimeType) { request.overrideMimeType('text/xml'); } } else if (window.ActiveXObject) { var versions = [ 'Microsoft.XMLHTTP', 'MSXML.XMLHTTP', 'Microsoft.XMLHTTP', 'Msxml2.XMLHTTP.7.0', 'Msxml2.XMLHTTP.6.0', 'Msxml2.XMLHTTP.5.0', 'Msxml2.XMLHTTP.4.0', 'MSXML2.XMLHTTP.3.0', 'MSXML2.XMLHTTP' ]; for ( var i = 0; i < versions.length; i++) { try { request = new ActiveXObject(versions[i]); if (request) { return request; } } catch (e) { } } } return request; } function ajax(xmlhttp, _method, _url, _param, _callback) { if (typeof xmlhttp == 'undefined') return; xmlhttp.onreadystatechange = function() { if (xmlhttp.readyState == 4 && xmlhttp.status == 200) { _callback(xmlhttp); } }; xmlhttp.open(_method, _url, true); if (_method == "POST") { xmlhttp.setRequestHeader("Content-Type", "application/x-www-form-urlencoded"); xmlhttp.setRequestHeader("Content-Length", _param.length); xmlhttp.send(_param); } else { xmlhttp.send(null); } } // 使用举例 var xmlhttp = createXMLHttpRequest(); var t1; // 用来作超时处理 function adduserok(request) { // alert(request.responseText); if (t1) clearTimeout(t1); } function connecttoFail() { if (xmlhttp) xmlhttp.abort(); // alert ('Time out'); } if (xmlhttp) { ajax(xmlhttp, "POST", "http://10.1.2.187/adduser.cgi", "act=do&user=abc", adduserok); t1 = setTimeout(connecttoFail, 30000); } else { alert("Init xmlhttprequest fail"); }2)上面这种手动处理ajax的适合初级阶段,如果使用jquery框架,那么在jquery中可以设置timeout超时属性:
$.ajax({ url:'', //请求的URL timeout : 1000, //超时时间设置,单位毫秒 type : 'get', //请求方式,get或post data :{}, //请求所传参数,json格式 dataType:'json',//返回的数据格式 success:function(data){ //请求成功的回调函数 alert("成功"); }, complete : function(XMLHttpRequest,status){ //请求完成后最终执行参数 if(status=='timeout'){//超时,status还有success,error等值的情况 ajaxTimeoutTest.abort(); alert("超时"); } } });3)xmlHttpRequest level2新版本中,增加了超时属性,并且有超时事件:
xhr.timeout = 3000; xhr.ontimeout = function(event){ alert('请求超时!'); }