Pro,Android学习笔记七一 HTTP服务5多线程调用
HttpClient
Pro Android学习笔记七一服务5 多线程调用用HttpClient文章只能用于非商业性质且不能带有虚拟货币、积分、注册等附加条件须注明出处 blog.csdn./flowingflying/应用共享
HttpClient对象的同步问题在之前的例子中HttpClient只用于某个请求我们可以为整个应用创建一个共享的HttpClient对象。这就存在多线程使用的问题而HttpClient已经考虑这个问题只需要创建一个使用ThreadSafeCli entConnManager的
DefaultHttpClient对象。
创建共享HttpClient代码创建共享对象创建共享对象的方式是通用如下public class CustomHttpClient { private static HttpClientclient = null ; //应用共享的对象/*采用采用private的构造器禁止了其他类通过CustomHttpClient xx = new
CustomHttpClient() ;这种方式创建对象确保对象的唯一性这种方式创建对象确保对象的唯一性*/private CustomHttpClient() { }/*通过静态调用获取对象第一次调用为空时进行创建*/ publ icstatic synchronized HttpClientgetCustomHttpClient() { if(client == null) { /*如果对象为空
创建之*/ . . . . . . } return client; } /*禁止禁止clone 同样也是保证对象的唯一性 同样也是保证对象的唯一性*/public Objectc() throws CloneNotSupportedException{ throw new
CloneNotSupportedException() ; } }
创建可共享的HttpClient对象下面给出上面中省略的部分当对象为空是创建HttpClient对象的代码为了方便理解代码从可以从后往前看。
// 【2. 1 】设置Http参数参数HttpParams params = newBasi cHttpParams() ; /*设置设置HttpParam是的基本参数是的基本参数其实都是对应请求的消息头。其中三个都很好理解重点介绍一些setUserExpectContinue。
一般都设置为flase设置为true通常是传递request消息很大
例携带大文件 而服务器可能需要认证我们不希望传完这个大文件才收到服务器的拒绝。是TCP流方式当server收到请求的头字段是Except 100-continue不在等待整个请求返回100continue应答继续读取或者给出拒绝请求final Status code如4xx 。
具体可以参
考 .w3/Protocols/rfc2616/rfc2616-sec8.html#sec8.2. 3 */Vers ion(params, HttpVersion._1_1) ;
HttpProtocolParams. setContentChars et(params, .DEFAULT_CONTENT_CHARSET) ; ExpectContinue(params, true) ;
HttpProtocolParams. setUserAgent(params, "Mozil la/5.0 (Linux;U; Android 2.2. 1 ; en-us; Nexus One Build/FRG83)" + "
AppleWebKit/533. 1 (KHTML, like Gecko) Version/4.0 MobileSafari/533. 1") ; /*设置超时时间。
设置超时时间。超时的异常均属于IOException此外
ClientProtocolException也是与IOException*/ //从
ClientConnect ionManager获取连接的时间这是从连接池中获取连接的超时设置只有在连接池所有连接都在使用的情况下才可能出现超时。超时会扔出ConnectionPoolTimeoutException。一个HttpClient对应管理器有连接池里面有多个连接socket 这是我对其架构的猜测。
ConnManagerParams. se tTi meout(params, 1000) ; //这是连接到远端web server的超时设置超时会扔出
ConnectTimeoutException
HttpConnectionParams. setConnect ionTimeout(params, 5000) ;//
连接超时//这是发送请求消息后最多等待多长时间得到响应的设置超时会扔出SocketTimeoutException
HttpConnectionParams. setSoTimeout(params, 10000) ;//socket超时// 【2.2 】设置Sheme 注册了和和s SchemeRegistry schReg= new SchemeRegistry() ;
",PlainSocketFactory.getSocketFactory() , 80)) ;schReg.register(new
Scheme("s",PlainSocketFactory.getSocketFactory() , 443) ) ; //
【2 】 ClientConnect ionManager用于管理连接我们使用同一个client用来处理请求要确保多线程的使用安全采用
ThreadSafeCli entConnManager 是线程安全的连接池。如果多个线程同时请求或有延迟情况。
是线程安全的连接池。如果多个线程同时请求或有延迟情况。
Cl ientConnectionManager conMgr = new
ThreadSafeCl i entConnManager(params, schReg) ; // 【1 】以ThreadSafeCli entConnManager为管理器参数创建可进行多线程调的用的同步保护的HttpClient对象对象client = new
DefaultHttpCl ient(conMgr,params) ;使用共享HttpClient对象的代码基础代码下面给出Activity调用这个共享的HttpClient的代码
public class HttpActivity extends Activity{ privateHttpClient client = null; protected void onCreate(BundlesavedInstanceState) {……//UI处理等client =
CustomHttpClient.getCustomHttpClient() ; getHttpContent() ; }private void getHttpContent() { try{ HttpGet request = newHttpGet(".google. ") ; /*在处理在处理response时利用Android提供的BasicResponseHandler handleResponse(HttpResponse response) Returns the responsebody as a String. if the response was suessful (a 2xx statuscode) . */ String page = client. execute(request,new
BasicResponseHandler() ) ;
Log.d("PRO-",page) ; }catch(IOExcepti one) { e.printStackTrace() ; } } }修改连接的参数我们在创建HttpClient时已经设置了有关的连接参数实际对应的是请求消息中的消息头如果某个请求需要对这些参数进行修改不应对公共属性进行修改否则会影响到其他请求而是通过对具体的request请求进行设置。代码例子如下
//我们设置了内部网的一个空地址通过LogCat中连接超时出现的时间来判断参数修改是否成功
HttpGet request =new HttpGet("192. 168.0. 199") ; //读取Ct的参数设置HttpParams cl ientParams=client.getParams() ;
Log.d("PRO-",Log.d(String.valueOf(HttpConnect ionParams.getConnectionTimeout(cl ientParams)) ) ;//显示为5000
Log.d("PRO-",String.valueOf(HttpConnect ionParams.getSoTimeout(clientParams) )) ;//显示为10000 //原来设置的连接超时是5秒下面将重新设置该参数设为20秒我们将新在的参数设置在request中将不影响其他的请求中将不影响其他的请求Paramsparams = request.getParams() ;
HttpConnectionParams. setConnect ionTimeout(params,
20000) ;//20s request. setParams(params) ;
Log.d("PRO-",String.valueOf(HttpConnect ionParams.getConnecti onTimeout(params)) ) ;//显示20000
Log.d("PRO-",String.valueOf(HttpConnect ionParams.getSoTimeout(params) )) ; //显示0使用共同的Appcl iat ion对象对于应用全局共享同一对象使人想起appcl i cat ion对象对于Andro id应用都会有一个application对象在在应用中可以通过getApplicationContext()或者getApplication()来获得。如果我们没有自定义的App l icati on类就是用andro id.app.Appl i cat ion。我们当然也可以将HttpClient对象放置在自定义的application类但是为了这点小事来是App l icati on类变得复杂并不可取。
在此我们将探讨自定义的Appcl i ati on。很简单只要创建自定义的Application类即可至于application对象的创建均有系统来完成。下面我们在自定义的App l icati on中加入一个计数器。import android.app.Application; public class
CustomApplication extends Application{ private int counter =0; public int getCounter() { return ++counter; } }
在应用的所有组件都都可以app l icati on对象且是唯一的一个。从运行结果看出获得这个对象有好几种方式。
CustomApplication app =
(CustomApplication)getApplication() ; unter: " +app.getCounter() ) ; //测试一下计数器是否正常pp) ;
Log.d("PRO-wei", "context: " + app.getApplicationContext() ) ;//测试一下获得app类的其他方式Log.d("PRO-wei", "context: "+getAppl icationContext()) ; //测试一下获得app类的其他方式本博文涉及的例子代码可以在Pro Android学习 Http service小例子中下载。
相关链接
我的Andro id开发相关文章模板,内容仅供参考
LightNode是一家成立于2002年,总部位于香港的VPS服务商。提供基于KVM虚拟化技术.支持CentOS、Ubuntu或者Windows等操作系统。公司名:厦门靠谱云股份有限公司官方网站:https://www.lightnode.com拥有高质量香港CN2 GIA与东南亚节点(河内、曼谷、迪拜等)。最低月付7.71美金,按时付费,可随时取消。灵活满足开发建站、游戏应用、外贸电商等需求。首...
Hostodo商家算是一个比较小众且运营比较久的服务商,而且还是率先硬盘更换成NVMe阵列的,目前有提供拉斯维加斯和迈阿密两个机房。看到商家这两年的促销套餐方案变化还是比较大的,每个月一般有这么两次的促销方案推送,可见商家也在想着提高一些客户量。毕竟即便再老的服务商,你不走出来让大家知道,迟早会落寞。目前,Hostodo有提供两款大流量的VPS主机促销,机房可选拉斯维加斯和迈阿密两个数据中心,且都...
继阿里云服务商推出轻量服务器后,腾讯云这两年对于轻量服务器的推广力度还是比较大的。实际上对于我们大部分网友用户来说,轻量服务器对于我们网站和一般的业务来说是绝对够用的。反而有些时候轻量服务器的带宽比CVM云服务器够大,配置也够好,更有是价格也便宜,所以对于初期的网站业务来说轻量服务器是够用的。这几天UCLOUD优刻得香港服务器稳定性不佳,于是有网友也在考虑搬迁到腾讯云服务器商家,对于轻量服务器官方...