URLConnection的连接、超时、关闭用法总结(转载)

  1. Java中可以使用HttpURLConnection来请求WEB资源。  
  2.   
  3.    
  4.   
  5. 1、 URL请求的类别   
  6.   
  7. 分为二类,GET与POST请求。二者的区别在于:  
  8.       a:) get请求可以获取静态页面,也可以把参数放在URL字串后面,传递给servlet,  
  9.       b:) post与get的不同之处在于post的参数不是放在URL字串里面,而是放在http请求的正文内。   
  10.   
  11.  
  12. 2、URLConnection的对象问题
  1.  
  2. URL url = new URL("http://localhost:8080/TestHttpURLConnectionPro.do");  
  3.   
  4. URLConnection rulConnection = url.openConnection();// 此处的urlConnection对象实际上是根据URL的  
  5.           // 请求协议(此处是http)生成的URLConnection类  
  6.           // 的子类HttpURLConnection,故此处最好将其转化  
  7.           // 为HttpURLConnection类型的对象,以便用到  
  8.           // HttpURLConnection更多的API.如下:  
  9.   
  10. HttpURLConnection httpUrlConnection = (HttpURLConnection) rulConnection;
  11.  
  12.  
  13. 3、HttpURLConnection对象参数问题 
  14.  
  15. Java代码      
  16. // 设置是否向httpUrlConnection输出,因为这个是post请求,参数要放在  
  17. // http正文内,因此需要设为true, 默认情况下是false;  
  18. httpUrlConnection.setDoOutput(true);  
  19.   
  20. // 设置是否从httpUrlConnection读入,默认情况下是true;  
  21. httpUrlConnection.setDoInput(true);  
  22.   
  23. // Post 请求不能使用缓存  
  24. httpUrlConnection.setUseCaches(false);  
  25.   
  26. // 设定传送的内容类型是可序列化的java对象  
  27. // (如果不设此项,在传送序列化对象时,当WEB服务默认的不是这种类型时可能抛java.io.EOFException)  
  28. httpUrlConnection.setRequestProperty("Content-type""application/x-java-serialized-object");  
  29.   
  30. // 设定请求的方法为"POST",默认是GET  
  31. httpUrlConnection.setRequestMethod("POST");  
  32.   
  33. // 连接,从上述第2条中url.openConnection()至此的配置必须要在connect之前完成,  
  34.         httpUrlConnection.connect();   
  35.   
  36. 4、HttpURLConnection连接问题  
  37.   
  38. Java代码      
  39. // 此处getOutputStream会隐含的进行connect(即:如同调用上面的connect()方法,  
  40. // 所以在开发中不调用上述的connect()也可以)。  
  41. OutputStream outStrm = httpUrlConnection.getOutputStream();   
  42.   
  43. 5、HttpURLConnection写数据与发送数据问题  
  44.   
  45. Java代码   
  46. // 现在通过输出流对象构建对象输出流对象,以实现输出可序列化的对象。  
  47. ObjectOutputStream objOutputStrm = new ObjectOutputStream(outStrm);  
  48.   
  49. // 向对象输出流写出数据,这些数据将存到内存缓冲区中  
  50. objOutputStrm.writeObject(new String("我是测试数据"));  
  51.   
  52. // 刷新对象输出流,将任何字节都写入潜在的流中(些处为ObjectOutputStream)  
  53. objOutputStm.flush();  
  54.   
  55. // 关闭流对象。此时,不能再向对象输出流写入任何数据,先前写入的数据存在于内存缓冲区中,  
  56. // 在调用下边的getInputStream()函数时才把准备好的http请求正式发送到服务器  
  57. objOutputStm.close();  
  58.   
  59. // 调用HttpURLConnection连接对象的getInputStream()函数,  
  60. // 将内存缓冲区中封装好的完整的HTTP请求电文发送到服务端。  
  61. InputStream inStrm = httpConn.getInputStream(); // <===注意,实际发送请求的代码段就在这里  
  62.   
  63. // 上边的httpConn.getInputStream()方法已调用,本次HTTP请求已结束,下边向对象输出流的输出已无意义,  
  64. // 既使对象输出流没有调用close()方法,下边的操作也不会向对象输出流写入任何数据.  
  65. // 因此,要重新发送数据时需要重新创建连接、重新设参数、重新创建流对象、重新写数据、  
  66. // 重新发送数据(至于是否不用重新这些操作需要再研究)  
  67. objOutputStm.writeObject(new String(""));  
  68. httpConn.getInputStream();   
  69.   
  70. 6、post参数的方法  
  71.   
  72. Java代码     
  73. OutputStream os = httpConn.getOutputStream();  
  74.             String param = new String();  
  75.             param = "CorpID=" + CorpID +  
  76.                     "&LoginName=" + LoginName+  
  77.                     "&send_no=" + phoneNumber +  
  78.                     "&msg=" + java.net.URLEncoder.encode(msg,"GBK"); ;  
  79.             os.write(param.getBytes());   
  80.   
  81. 7、超时设置,防止 网络异常的情况下,可能会导致程序僵死而不继续往下执行   
  82.   
  83. Java代码   
  84. System.setProperty("sun.net.client.defaultConnectTimeout""30000");  
  85. System.setProperty("sun.net.client.defaultReadTimeout""30000");  
  86.   
  87. 其中: sun.net.client.defaultConnectTimeout:连接主机的超时时间(单位:毫秒)  
  88. sun.net.client.defaultReadTimeout:从主机读取数据的超时时间(单位:毫秒)  
  89.   
  90. JDK 1.5以前的版本,只能通过设置这两个系统属性来控制网络超时。在1.5中,还可以使用HttpURLConnection的父类URLConnection的以下两个方法:  
  91. setConnectTimeout:设置连接主机超时(单位:毫秒)  
  92. setReadTimeout:设置从主机读取数据超时(单位:毫秒)  
  93.   
  94. 例如:  
  95. HttpURLConnection urlCon = (HttpURLConnection)url.openConnection();  
  96. urlCon.setConnectTimeout(30000);  
  97. urlCon.setReadTimeout(30000);   
  98.   
  99.   
  100.   
  101. 总结:   
  102.   
  103.   
  104. a: HttpURLConnection的connect()函数,实际上只是建立了一个与服务器的tcp连接,并没有实际发送http请求。  
  105.     无论是post还是get,http请求实际上直到HttpURLConnection的getInputStream()这个函数里面才正式发送出去。  
  106.  b:在用POST方式发送URL请求时,URL请求参数的设定顺序是重中之重,  
  107.     对connection对象的一切配置(那一堆set函数)  
  108.     都必须要在connect()函数执行之前完成。而对outputStream的写操作,又必须要在inputStream的读操作之前。  
  109.     这些顺序实际上是由http请求的格式决定的。  
  110.     如果inputStream读操作在outputStream的写操作之前,会抛出例外:  
  111.     java.net.ProtocolException: Cannot write output after reading input.......        
  112.  c:http请求实际上由两部分组成,一个是http头,所有关于此次http请求的配置都在http头里面定义,一个是正文       content。connect()函数会根据HttpURLConnection对象的配置值生成http头部信息,因此在调用connect函数之前, 
  113.     就必须把所有的配置准备好。  
  114.  d: 在http头后面紧跟着的是http请求的正文,正文的内容是通过outputStream流写入的,  
  115.     实际上outputStream不是一个网络流,充其量是个字符串流,往里面写入的东西不会立即发送到网络,  
  116.     而是存在于内存缓冲区中,待outputStream流关闭时,根据输入的内容生成http正文。  
  117.     至此,http请求的东西已经全部准备就绪。在getInputStream()函数调用的时候,就会把准备好的http请求  
  118.     正式发送到服务器了,然后返回一个输入流,用于读取服务器对于此次http请求的返回信息。由于http  
  119.     请求在getInputStream的时候已经发送出去了(包括http头和正文),因此在getInputStream()函数  
  120.     之后对connection对象进行设置(对http头的信息进行修改)或者写入outputStream(对正文进行修改)  
  121.     都是没有意义的了,执行这些操作会导致异常的发生。
当我们在使用git clone命令时,有时会遇到连接超时的问题。这可能是由于网络不稳定或者服务器负载过高导致的。要解决git clone连接超时的问题,有以下几种方法可以尝试: 1. 检查网络连接:确保您的电脑能够正常访问互联网,网络连接稳定。您可以尝试打开其他网页或应用程序来检查网络连接是否正常。 2. 使用代理:如果您正在使用公司或学校网络,可能需要设置代理才能访问外部网络。您可以尝试配置代理设置,并重新运行git clone命令。 3. 使用HTTPS连接:尝试使用HTTPS而不是SSH连接。某些网络可能会阻止SSH连接,而HTTPS连接通常更容易通过防火墙。 4. 使用不同的git客户端:尝试使用不同的git客户端,如GitKraken或SourceTree。有时候不同的客户端可能有不同的网络设置和连接方式,可能会解决连接超时的问题。 5. 更改URL为IP地址:尝试将git clone命令中的URL更改为服务器的IP地址,有时候域名解析可能会导致连接超时。 6. 使用--depth 1参数:您可以尝试在git clone命令中加入--depth 1参数,这样只会克隆最新版本的代码,可以减少克隆的数据量,可能会提高连接速度。 7. 检查防火墙设置:检查防火墙设置是否阻止了git clone的端口。您可以尝试暂时关闭防火墙或者配置防火墙规则来允许git clone的端口通过。 通过以上方法,您应该能够解决git clone连接超时的问题。如果问题仍然存在,您可以尝试联系网络管理员或者咨询git相关的技术支持。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值