当前位置: 首页 > 编程笔记 >

Java  HttpURLConnection超时和IO异常处理

金骞尧
2023-03-14
本文向大家介绍Java  HttpURLConnection超时和IO异常处理,包括了Java  HttpURLConnection超时和IO异常处理的使用技巧和注意事项,需要的朋友参考一下

最近同步数据的时候发现了一个问题,我本身后台插入数据后给其他部门后台做同步。说简单一点其实就是调用对方提供的接口,进行HTTP请求调用。然后后面发现问题了。HTTP请求的话,有可能请求超时,中断失败,IO异常其实都有可能,如果是平时打开一个网页还好,打不开的时候,你会关掉,或者他页面给你显示信息。但是同步,不可以这样做,一旦请求失败,必须让数据正确的同步,今天才意识到这个问题的重要性。

String httpUrl = "https://www.baidu.com/s?ie=UTF-8&tn=90594569_hao_pg&wd=1"; 
URL url = null; 
HttpURLConnection httpConn = null; 
String result = ""; 
try { 
  String address = httpUrl; 
  url = new URL(address); 
  httpConn = (HttpURLConnection) url.openConnection(); 
   
  //A URL connection can be used for input and/or output. Set the  
  //DoInput flag to true if you intend to use the URL connection for input, 
  //false if not. The default is true.  
   
  //URL连接可用于input或output。如果想用URL连接输入,设置DoInput标签为true。 
  //输入和输出是针对计算机的,如果以程序员的角度考虑,经常弄混。 
  //input输入,output输出,那么不是从output里read,input中write吗,其实相反 
  //input输入进计算机,计算机才能读,所以是从input read,而output是计算机输出,通过output write。 
  httpConn.setDoOutput(false); 
  //所以如果setDoInput(false),想从URLConnection读取时不能读取 
  //Cannot read from URLConnection if doInput=false (call setDoInput(true))  
  httpConn.setDoInput(true); 
   
  //连接建立超时时间还有读取数据超时时间, 
  httpConn.setConnectTimeout(600000); 
  httpConn.setReadTimeout(600000); 
  httpConn.setRequestMethod("GET"); 
  httpConn.connect(); 
  
  //获取状态码 
  int code = httpConn.getResponseCode(); 
  System.out.println(code); 
  //读http请求响应 
  BufferedReader reader = new BufferedReader(new InputStreamReader(httpConn.getInputStream())); 
  String line; 
  while ((line = reader.readLine()) != null) 
  { 
    result = result + line+"\n"; 
  } 
  System.out.println(result); 
  //关闭IO和连接 
  reader.close(); 
  httpConn.disconnect(); 
} 
catch(Exception e){ 
  log.error(e); 
} 
finally{ 
  if(httpConn!=null) 
    httpConn.disconnect(); 
} 

代码看上去写的没什么,该释放资源的地方也释放了。该打日志输出的也打了。其实问题就是异常的处理。之前以为一些东西没有同步过去是因为连接超时的问题。所以特地捕获SocketTimeoutException异常,后面看了日志之后,发现是同步接口那边服务器的问题,报了502错误。其实异常是IO异常。

无论是那种情况,我们都要在出现这种问题之后,再次地把请求发送过去,根据接口返回的结果,确认对方已经同步到。如果服务器暂时性的出了问题,我们可以暂停一小段时间后,然后再次请求。

所以暂时想到的方法是,由于同步的实时性要求不高,那么可以间隔的时间可以长一点。然后循环,另起线程,每次间隔5分钟,直至结果正常。

catch(Exception e){ 
  for (int i = 0; i < 6; i++) { 
    Thread t = new Thread(){public void run(){get();}}; 
    t.start(); 
    if(result.equals("ok")){ 
      break; 
    } 
    try { 
      Thread.sleep(300000); 
    } catch (InterruptedException e2) { 
      log.error(e2); 
    } 
  } 
  log.error(e); 
} 





以上就是对Java  HttpURLConnection超时和IO异常处理的资料整理,后续继续补充相关资料,谢谢大家对本站的支持!

 类似资料:
  • 问题是,我想写一个Java程序来增加特定URL的页面点击量。目前我只是在网上冲浪,并得到一些基本的程序来做测试。然而,我甚至无法使程序运行...下面是我的程序和相关输出。 Eclipse、Java程序: 以下是输出: 线程“main”java.net.ConnectException:连接超时:java.net.plainsockeTimpl.SocketConnect(本机方法)java.net

  • 我需要应用程序将错误写入位置。有没有我可以用Java异常处理做这件事?我已经在抛接IOerrors了,所以我不知道问题出在哪里……? 我正在从标准输入读取数据,并将其压缩并写入标准输出。 写入/dev/full不是引发异常...有没有关于如何引发异常的想法?

  • 问题内容: 这是我目前拥有的代码: 一切都会按预期进行(调用writeToFile方法时将文件写入)。但是,当第二次调用writeToFile方法时,出现以下错误: 该文件仍按预期第二次写入,但是它将在第二次以及以后对writeToFile()的调用中引发此错误。我想知道是什么导致此错误发生。 问题答案: 写完后就在打电话。流关闭后,将无法再次写入。通常,实现此目标的方法是将结束状态移至write

  • 我尝试调用getCodeResponse()时遇到IOException。当参数有效时,没有异常,代码响应为200。如果参数错误,服务器应返回401代码。我已经测试了Hull的查询。如果参数错误,我会得到401代码。当出现错误代码时,HttpURLConnection类可能会引发异常。

  • 我们在生产方面面临以下问题: 是因为无效的配置,如批量大小、请求超时或其他原因吗?

  • 我在非GUI模式下为100个并发用户运行了一个脚本 我在运行期间保存了生成的 JTL 文件 运行完成后,我在查看结果树侦听器中加载了JTL文件,我可以看到如下错误: 响应代码: 非 HTTP 响应代码: 套接字超时异常 响应消息: 非 HTTP 响应消息: 读取超时 响应代码:非HTTP响应代码:Java . net . connect异常响应消息:非HTTP响应消息:连接超时:连接 我的JMet