`

HttpURLConnection详解

阅读更多

项目中用到HttpURLConnection,远程连接客户端,具体代码

1.Memory.java

public enum Memory {
	Dictionary {
		@Override
		public String getName() {
			return "com.hanpeng.base.util.memoryCtrl.DictionaryCtrl";
		}
	},
	Config {
		@Override
		public String getName() {
			return "com.hanpeng.base.util.memoryCtrl.ConfigCtrl";
		}
	} ,
	BussinessRole{
		public String getName() {
			return "com.hanpeng.base.util.memoryCtrl.BussinessRoleCtrl";
		}
	},
	BussinessRolePriv{
		public String getName() {
			return "com.hanpeng.base.util.memoryCtrl.BussinessRolePrivCtrl";
		}
	}
	;
	
	public abstract String getName();
	
}

 

2.MemoryUpdate.java

	/**
	 * 更新b2cPlatform(前台)内存
	 * @param cn
	 * @return 0成功 1失败
	 * @throws IOException
	 * @author lvwenyong
	 * @date 2011-6-7 下午01:18:20
	 */
	public static String clientUpdate(String cn) throws IOException {
		BufferedReader br = null;
		try {
			URL url = new URL(ConfigCtrl
					.getConfigValue("client_memory_reload_url")
					// "http://192.168.10.123:8888"
					+ "/b2cPlatform/memory_reload.action?cn=" + Memory.valueOf(cn).getName());
			HttpURLConnection conn = (HttpURLConnection) url.openConnection();
			conn.setDoInput(true);
			conn.setDoOutput(true);
			conn.getContent();
//			System.out.println("type======" + conn.getContentType());
			br = new BufferedReader(
					new InputStreamReader(conn.getInputStream()));
			String state =  br.readLine();//0成功 1失败
			return state;
		} finally {
			if (br != null)
				br.close();
		}
	}
	
	/**
	 * 更新managerPlatform(后台)内存
	 * @param cn
	 * @return
	 * @throws Exception
	 * @author lvwenyong
	 * @date 2011-6-7 下午01:18:56
	 */
	@SuppressWarnings("unchecked")
	public static String serverUpdate(String cn) throws Exception {
		Class clazz = Class.forName(Memory.valueOf(cn).getName());
		Method m = clazz.getDeclaredMethod("load"
				+ clazz.getSimpleName().replace("Ctrl", ""));
		m.invoke(clazz);
		return "0";
	}

 

3.调用

/**
 * 修改商户角色的权限
*/
businessRoleService.updateTBussinessRoleForImpower(bussinessRole);
			
MemoryUpdate.clientUpdate("BussinessRole");//更新前台内存中的Role

MemoryUpdate.clientUpdate("BussinessRolePriv");//更新前台内存中的RolePriv

 

-------------------------------------------------------------------------------------------------------------------------------------------------------------------

转载的文章:

HttpURLConnection用法详解

下边的总结对我帮助蛮大的~不仅用法了解,整个连接流程也要明白!

原文链接地址: 
http://www.blogjava.net/supercrsky/articles/247449.html 

针对JDK中的URLConnection连接Servlet的问题,网上有虽然有所涉及,但是只是说明了某一个或几个问题,是以FAQ的方式来解决的,而且比较零散,现在对这个类的使用就本人在项目中的使用经验做如下总结: 
1:> URL请求的类别: 
分为二类,GET与POST请求。二者的区别在于: 
     a:) get请求可以获取静态页面,也可以把参数放在URL字串后面,传递给servlet, 
     b:) post与get的不同之处在于post的参数不是放在URL字串里面,而是放在http请求的正文内。 


2:> URLConnection的对象问题: 
URLConnection的对象,如下代码示例: 

// 下面的index.jsp由<servlet-mapping>映射到 
// 一个Servlet(com.quantanetwork.getClientDataServlet) 
// 该Servlet的注意点下边会提到 

1 URL url = new URL("http://localhost:8080/TestHttpURLConnectionPro/index.jsp"); 2 3 URLConnection rulConnection = url.openConnection(); 4 // 此处的urlConnection对象实际上是根据URL的 5 // 请求协议(此处是http)生成的URLConnection类 6 // 的子类HttpURLConnection,故此处最好将其转化 7 // 为HttpURLConnection类型的对象,以便用到 8 // HttpURLConnection更多的API.如下: 9   10 HttpURLConnection httpUrlConnection = (HttpURLConnection) rulConnection;

3:> HttpURLConnection对象参数问题 

1 // 设置是否向httpUrlConnection输出,因为这个是post请求,参数要放在 2  // http正文内,因此需要设为true, 默认情况下是false; 3  httpUrlConnection.setDoOutput(true); 4 5  // 设置是否从httpUrlConnection读入,默认情况下是true; 6  httpUrlConnection.setDoInput(true); 7 8  // Post 请求不能使用缓存 9  httpUrlConnection.setUseCaches(false); 10 11  // 设定传送的内容类型是可序列化的java对象 12  // (如果不设此项,在传送序列化对象时,当WEB服务默认的不是这种类型时可能抛java.io.EOFException) 13  httpUrlConnection.setRequestProperty("Content-type", "application/x-java-serialized-object"); 14 15  // 设定请求的方法为"POST",默认是GET 16  httpUrlConnection.setRequestMethod("POST"); 17 18  // 连接,从上述第2条中url.openConnection()至此的配置必须要在connect之前完成, 19   httpUrlConnection.connect();

4:>  HttpURLConnection连接问题: 

1 // 此处getOutputStream会隐含的进行connect(即:如同调用上面的connect()方法, 2  // 所以在开发中不调用上述的connect()也可以)。 3  OutputStream outStrm = httpUrlConnection.getOutputStream();

5:> HttpURLConnection写数据与发送数据问题: 

1 1 // 现在通过输出流对象构建对象输出流对象,以实现输出可序列化的对象。 2   2 ObjectOutputStream objOutputStrm = new ObjectOutputStream(outStrm); 3 3 4 4 // 向对象输出流写出数据,这些数据将存到内存缓冲区中 5   5 objOutputStrm.writeObject(new String("我是测试数据")); 6 6 7 7 // 刷新对象输出流,将任何字节都写入潜在的流中(些处为ObjectOutputStream) 8   8 objOutputStm.flush(); 9 9 10  10 // 关闭流对象。此时,不能再向对象输出流写入任何数据,先前写入的数据存在于内存缓冲区中, 11  11 // 在调用下边的getInputStream()函数时才把准备好的http请求正式发送到服务器 12  12 objOutputStm.close(); 13  13 14  14 // 调用HttpURLConnection连接对象的getInputStream()函数, 15  15 // 将内存缓冲区中封装好的完整的HTTP请求电文发送到服务端。 16  16 InputStream inStrm = httpConn.getInputStream(); // <===注意,实际发送请求的代码段就在这里 17  17 18 18 // 上边的httpConn.getInputStream()方法已调用,本次HTTP请求已结束,下边向对象输出流的输出已无意义, 19 19 // 既使对象输出流没有调用close()方法,下边的操作也不会向对象输出流写入任何数据. 20 20 // 因此,要重新发送数据时需要重新创建连接、重新设参数、重新创建流对象、重新写数据、 21 21 // 重新发送数据(至于是否不用重新这些操作需要再研究) 22 22 objOutputStm.writeObject(new String("")); 23 23 httpConn.getInputStream()

总结:a:) HttpURLConnection的connect()函数,实际上只是建立了一个与服务器的tcp连接,并没有实际发送http请求。 

    无论是post还是get,http请求实际上直到HttpURLConnection的getInputStream()这个函数里面才正式发送出去。 
       b:) 在用POST方式发送URL请求时,URL请求参数的设定顺序是重中之重, 
    对connection对象的一切配置(那一堆set函数) 
    都必须要在connect()函数执行之前完成。而对outputStream的写操作,又必须要在inputStream的读操作之前。 
    这些顺序实际上是由http请求的格式决定的。 
    如果inputStream读操作在outputStream的写操作之前,会抛出例外: 
    java.net.ProtocolException: Cannot write output after reading input....... 
       
       c:) http请求实际上由两部分组成, 
    一个是http头,所有关于此次http请求的配置都在http头里面定义, 
           一个是正文content。 
    connect()函数会根据HttpURLConnection对象的配置值生成http头部信息,因此在调用connect函数之前, 
    就必须把所有的配置准备好。 
       d:) 在http头后面紧跟着的是http请求的正文,正文的内容是通过outputStream流写入的, 
    实际上outputStream不是一个网络流,充其量是个字符串流,往里面写入的东西不会立即发送到网络, 
    而是存在于内存缓冲区中,待outputStream流关闭时,根据输入的内容生成http正文。 
    至此,http请求的东西已经全部准备就绪。在getInputStream()函数调用的时候,就会把准备好的http请求 
    正式发送到服务器了,然后返回一个输入流,用于读取服务器对于此次http请求的返回信息。由于http 
    请求在getInputStream的时候已经发送出去了(包括http头和正文),因此在getInputStream()函数 
    之后对connection对象进行设置(对http头的信息进行修改)或者写入outputStream(对正文进行修改) 
    都是没有意义的了,执行这些操作会导致异常的发生。 

6:> Servlet端的开发注意点: 
a:) 对于客户端发送的POST类型的HTTP请求,Servlet必须实现doPost方法,而不能用doGet方法。 
b:) 用HttpServletRequest的getInputStream()方法取得InputStream的对象,比如: 
     InputStream inStream = httpRequest.getInputStream(); 
     现在调用inStream.available()(该方法用于“返回此输入流下一个方法调用可以不受阻塞地 
     从此输入流读取(或跳过)的估计字节数”)时,永远都反回0。试图使用此方法的返回值分配缓冲区, 
     以保存此流所有数据的做法是不正确的。那么,现在的解决办法是 
     Servlet这一端用如下实现: 
     InputStream inStream = httpRequest.getInputStream(); 
     ObjectInputStream objInStream = new ObjectInputStream(inStream); 
     Object obj = objInStream.readObject(); 
     // 做后续的处理 
     // 。。。。。。 
     // 。。。 。。。 
     而客户端,无论是否发送实际数据都要写入一个对象(那怕这个对象不用),如: 
     ObjectOutputStream objOutputStrm = new ObjectOutputStream(outStrm); 
     objOutputStrm.writeObject(new String("")); // 这里发送一个空数据 
     // 甚至可以发一个null对象,服务端取到后再做判断处理。 
     objOutputStrm.writeObject(null); 
     objOutputStrm.flush(); 
     objOutputStrm.close(); 

注意:上述在创建对象输出流ObjectOutputStream时,如果将从HttpServletRequest取得的输入流 
      (即:new ObjectOutputStream(outStrm)中的outStrm)包装在BufferedOutputStream流里面, 
      则必须有objOutputStrm.flush();这一句,以便将流信息刷入缓冲输出流.如下: 
      ObjectOutputStream objOutputStrm = new ObjectOutputStream(new BufferedOutputStream(outStrm)); 
      objOutputStrm.writeObject(null); 
      objOutputStrm.flush(); // <======此处必须要有. 
      objOutputStrm.close(); 

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.defaultReadTime 

Java中可以使用HttpURLConnection来请求WEB资源。 
HttpURLConnection对象不能直接构造,需要通过URL.openConnection()来获得HttpURLConnection对象,示例代码如下: 

1 String szUrl = "http://www.ee2ee.com/"; 2 URL url = new URL(szUrl); 3 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:设置从主机读取数据超时(单位:毫秒) 

例如: 
1 HttpURLConnection urlCon = (HttpURLConnection)url.openConnection(); 2 urlCon.setConnectTimeout(30000); 3 urlCon.setReadTimeout(30000);
  


需要注意的是,笔者在JDK1.4.2环境下,发现在设置了defaultReadTimeout的情况下,如果发生网络超时,HttpURLConnection会自动重新提交一次请求,出现一次请求调用,请求服务器两次的问题(Trouble)。我认为这是JDK1.4.2的一个bug。在JDK1.5.0中,此问题已得到解决,不存在自动重发现象。out", "3000
分享到:
评论
1 楼 tuspark 2015-09-20  
讲解的很不错。URLConnection类的内容也可以看这篇文章:[url= http://swiftlet.net/archives/1473]《URL类和URLConnection类介绍》[/url],讲解的也很详细。

相关推荐

    Android网络技术HttpURLConnection详解

    主要为大家详细介绍了Android网络技术HttpURLConnection的相关资料,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

    HttpURLConnection用法详解

    HttpURLConnection用法详解, 轻松掌握HttpURLConnection开发原理

    Android代码-AndroidNote Android笔记

    HttpURLConnection详解 HttpURLConnection与HttpClient volley-retrofit-okhttp之我们该如何选择网路框架 Volley源码分析 Retrofit详解(上) Retrofit详解(下) Dagger2 1.Dagger2简介(一).md 2.Dagger2入门...

    Java 中HttpURLConnection附件上传的实例详解

    主要介绍了Java 中HttpURLConnection附件上传的实例详解的相关资料,希望通过本文大家能掌握这样的知识内容,需要的朋友可以参考下

    Java HttpURLConnection使用方法详解

    主要为大家详细介绍了Java HttpURLConnection使用方法,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

    Android开发使用HttpURLConnection进行网络编程详解【附源码下载】

    本文实例讲述了Android开发使用HttpURLConnection进行网络编程。分享给大家供大家参考,具体如下: ——HttpURLConnection URLConnection已经可以非常方便地与指定站点交换信息,URLConnection下还有一个子类:...

    Android典型技术模块开发详解

    2.2 HelloAndroid详解 2.2.1 程序结构 2.2.2 代码分析 2.3 权限permission 2.4 LogCat日志调试 2.5 示例练习 2.5.1 登录界面 2.5.2 事件处理 2.6 本章小结 第二篇 Android开发关键组件 第3章 Activity(活动) 3.1 ...

    Android OkHttp基本使用详解

    尽管Google在大部分安卓版本中推荐使用HttpURLConnection,但是这个类相比HttpClient实在是太难用,太弱爆了。 OkHttp是一个相对成熟的解决方案,据说Android4.4的源码中可以看到HttpURLConnection已经替换成OkHttp...

    java利用java.net.URLConnection发送HTTP请求的方法详解

    如何通过Java(模拟浏览器)发送HTTP请求是我们在日常经常会遇到的问题,下面这篇文章主要给大家介绍了关于java利用java.net.URLConnection发送HTTP请求的相关资料,文中介绍的非常详细,需要的朋友可以参考借鉴,...

    AndroidHttpClient详解及调用示例

    然后阿帕奇的HttpClient是对java中HttpUrlConnection的一个封装,感觉阿帕奇封装的还是不错的, 特别是其中的HttpEntity,很强大也很好用,能在android手机上上传百M的文件到服务器,还是不错的。 一: Android...

    Android调试神器stetho使用详解和改造

    Network Inspection:网络抓包,如果你使用的是当前流行的OkHttp或者Android自带的 HttpURLConnection,你可以轻松地在chrome inspect窗口的network一栏抓到所有的网络请求和回包,还用啥Postman,还用啥Fiddler哦...

    Android通过访问网页查看网页源码实例详解

    Android通过访问网页查看网页源码 1.添加网络权限 &lt;!--访问网络的权限--&gt; 2.获取网络中网页的数据 ... public static String getHtml(String path) throws Exception { ... HttpURLConnection conn=(HttpURLConn

    Android编程开发实现带进度条和百分比的多线程下载

    继上一篇《java多线程下载实例详解》之后,可以将它移植到我们的安卓中来,下面是具体实现源码: DownActivity.java: package com.example.downloads; import java.io.File; import java.io.IOException; import ...

    android开发揭秘PDF

    8.2.1 HttpURLConnection接口 8.2.2 HttpClient接口 8.2.3 实时更新 8.3 Socket通信 8.3.1 Socket基础 8.3.2 Socket应用(简易聊天室) 8.4 网络通信的中文乱码问题 8.5 WebKit应用 8.5.1 WebKjt概述 8.5.2 WebView...

    《Android应用开发揭秘》附带光盘代码.

     8.2.1 HttpURLConnection接口  8.2.2 HttpClient接口  8.2.3 实时更新  8.3 Socket通信  8.3.1 Socket基础  8.3.2 Socket应用(简易聊天室)  8.4 网络通信的中文乱码问题  8.5 WebKit应用  8.5.1 WebKjt...

    《Android应用开发揭秘》源码

     8.2.1 HttpURLConnection接口  8.2.2 HttpClient接口  8.2.3 实时更新  8.3 Socket通信  8.3.1 Socket基础  8.3.2 Socket应用(简易聊天室)  8.4 网络通信的中文乱码问题  8.5 WebKit应用  8.5.1 WebKjt...

Global site tag (gtag.js) - Google Analytics