jdk1.3,用url.openConnection,如果远程地址响应很慢,或者宕机,对于我这边是不是就是一直等待啊?直到超时?

解决方案 »

  1.   

    Java中可以使用HttpURLConnection来请求WEB资源。 
    HttpURLConnection对象不能直接构造,需要通过URL.openConnection()来获得HttpURLConnection对象,示例代码如下: 
    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:从主机读取数据的超时时间(单位:毫秒) 
    例如: 
    System.setProperty("sun.net.client.defaultConnectTimeout", "30000"); 
    System.setProperty("sun.net.client.defaultReadTimeout", "30000"); 
    JDK 1.5以前的版本,只能通过设置这两个系统属性来控制网络超时。在1.5中,还可以使用HttpURLConnection的父类URLConnection的以下两个方法: 
    setConnectTimeout:设置连接主机超时(单位:毫秒) 
    setReadTimeout:设置从主机读取数据超时(单位:毫秒) 
    例如: 
    HttpURLConnection urlCon = (HttpURLConnection)url.openConnection(); 
    urlCon.setConnectTimeout(30000); 
    urlCon.setReadTimeout(30000); 
    需要注意的是,在JDK1.4.2环境下,发现在设置了defaultReadTimeout的情况下,如果发生网络超时,HttpURLConnection会自动重新提交一次请求,出现一次请求调用,请求服务器两次的问题
      

  2.   

    HI,我想问一下,我在domino中写了个java代理,domino的jdk是1.3的,我设置了这个确实可以超时,但是那个时间不起作用,无论我设置是多少,30000和30000000都是一秒的时间,这是什么原因?
      

  3.   

    抱歉,刚才没看后台,是报错了,
    [106614:00213-15582] 2008-11-18 11:27:13   HTTP JVM: java.security.AccessControlException: access denied (java.util.PropertyPermission sun.net.client.defaultConnectTimeout write)
    [106614:00213-15582] 2008-11-18 11:27:13   HTTP JVM:  at java.security.AccessControlContext.checkPermission(AccessControlContext.java:286)
    [106614:00213-15582] 2008-11-18 11:27:13   HTTP JVM:  at java.security.AccessController.checkPermission(AccessController.java:413)
    这是什么意思?
      

  4.   

    我写了一个多线程(目前20个线程)发送http请求的程序,也设了超时时间,但是好像所有线程用的一个超时间,最后一起返回,并且本来应该有响应的server也没有连上,有人碰到国这个问题吗。
    目前我把每个请求的超时时间都依次递增一倍就可以正常响应了,但是这样一来最后几个请求的超时时间会变的超级长,很慢,谁能解释一下为什么会有这种问题啊