㈠ android 中有没有好的tcp长连接框架
可以试试开源的框架:rxnetty
使用rxnetty只需要简单的几句话就能解决netty tcp长连接的实现过程,由于没有handler所以使用一个方法再其他程序中使用能够更加的方便;还有就是在使用可以通过使Lambda 表达式来简化代码,使代码的可读性能够增加,还有就是在使用长链接的时候推荐使用rxAndroid,使用这个方法最主要的好处就是子线程可以很容易的将数据发送到主线程来更新界面
㈡ android几种网络框架的比较
现在 OkHttp 已经一统 android 的江山,但是基于 OkHttp 再次封装的 框架层出不穷
推荐直接使用 OkHttp 的增强版本 OkHttps , 15秒便可上手,超级好用,这是官方中文文档地址:okhttps.ejlchina.com
㈢ 如何在Android开发中高效使用Volley网络框架
Volley是Google在Google I/O 2013上发布的一个网络框架,主要功能:web接口请求,网络图片异步下载,支持缓存。volley只是定义了缓存以及Request的接口,具体实现可以自己定义,例如lru磁盘缓存,内存缓存,下载图片的ImageRequest.
Volley的源代码里包含了一些实现,都在com.android.volley.toolbox包里,包括磁盘缓存、json请求,图片请求。还定义了一个继承自ImageView的NetworkImageView,可以异步载入网络图片。
㈣ Android面试网络框架封装我应该说什么
rxjava2+retrofit+mvp
㈤ android怎么用okhttp封装网络框架
封装只是为了能更加简单,仅此而已~
功能
UI 线程切换
可选择的Callback(任意选择UI线程或者子线程)
参数规范化,GET与POST都一样的传参方式
上传/下载进度回调
可以简单的设置Head部分
可以每次请求时自动加上需要的参数
String/JSON/byte/File… 都能一样简单
用法
由于辅助代码较多,在这里就不一一贴出来了,在这里仅仅演示如何使用。
异步GET
Http.getAsync("http://wthrcdn.etouch.cn/weather_mini", new UiCallback<String>() {
@Override
public void onFailure(Request request, Response response, Exception e) {
log("getAsync:onFailed");
}
@Override
public void onSuccess(String response, int code) {
log("getAsync:onSuccess:" + response);
}
}, new StrParam("citykey", 101010100)
);123456789101112
由于是 get 请求,在这里参数中的 citykey 会被自动解析到 url 中。
http://wthrcdn.etouch.cn/weather_mini?citykey=1010101001
同步GET
final String url = "http://wthrcdn.etouch.cn/weather_mini?citykey=101010100";
String str = Http.getSync(String.class, url);
log("getSync1:" + str);
str = Http.getSync(url, new ThreadCallback<String>() {
@Override
public void onFailure(Request request, Response response, Exception e) {
log("getSync2:onFailed");
}
@Override
public void onSuccess(String response, int code) {
log("getSync2:onSuccess:" + response);
}
});
log("getSync2:" + str);12345678910111213141516
同步方式支持两种情况,一种有Callback,一种是没有。
当然就算加上了Callback也并不是异步,此时方法会等到执行完成后才会继续往下走。之所以这么干,是为了方便在callback中直接处理ui的事儿。
在这里有必要说明一下,返回类型需要进行指定,如果没有Callback哪么需要你传入返回类型class。
当然如果你传入了callback,哪么此时class就由callback
Account account = Http.getSync(Account.class, url);
User user = Http.getSync(User.class, url);
String str = Http.getSync(String.class, url, new StrParam("citykey", 101010100));123
Callback 的情况也如上所示。
异步与同步的区别在于方法名称:
Http.getSync()
Http.getAsync()
Http.postSync()
Http.postAsync()
Http.uploadSync()
Http.uploadAsync()
Http.downloadSync()
Http.downloadAsync()
默认情况下,upload与download具有callProgress 回调进度功能。
POST
String value1 = "xxx";
String value2 = "xxx";
String url = "http://www..com";
Http.postAsync(url, new HttpCallback<String>() {
@Override
public void onFailure(Request request, Response response, Exception e) {
e.printStackTrace();
}
@Override
public void onSuccess(String response, int code) {
log(response);
}
},
new StrParam("value1", value1),
new StrParam("value2", value2));1234567891011121314151617
post 的请求方法与get基本如出一辙。
Upload
File file = getAssetsFile();
Http.uploadAsync("http://img.hoop8.com/upload.php", "uploadimg", file, new UiCallback<String>() {
@Override
public void onProgress(long current, long count) {
super.onProgress(current, count);
log("uploadAsync onProgress:" + current + "/" + count);
mUpload.setProgress((int) ((current * 100.00 / count)));
}
@Override
public void onFailure(Request request, Response response, Exception e) {
e.printStackTrace();
log("uploadAsync onFailed");
}
@Override
public void onSuccess(String response, int code) {
log("uploadAsync onSuccess:" + response);
}
});
上传部分也很简单,如果需要带有参数哪么和Post的使用方式一样。当然此时传入参数就不是 StrParam 而是 IOParam.
上传的时候你可以仅仅传递文件+文件对应的name;或者 传递 IOParam; 也可以 StrParam+IOParam的方式;当然终极一点你可以传递:Param 类型。
㈥ android网络框架为什么要二次封装
②认知主义理论基础:
早在20世纪,20年代人们就发现行为主义的局限性。托尔曼在老鼠走迷宫的实验中发现老鼠在实验中表现出在利用认知地图走迷宫。当把迷宫的一部分关闭,老鼠并没有显得惊慌失措,好象它知道关闭的那部分本来就是走不通的,在视觉上,老鼠不可能看到那条路是行不通的,但它仍然选择走一条较长的路线,它知道那会是出路。
行为主义理论不能解释某些社会行为,儿童并不是模仿每个被强化的行为,例如他们会模仿一些他们初次观察到的行为,尽管这些行为并没有被强化。
㈦ Android中访问网络的框架有哪些
回答
Android中访问网络的框架有哪些?
请列举四种访问网络的框架(有什么特点并介绍)简短一些就好。
展开
Android开发 Android应用 Android 开发 App
㈧ android大量数据网络上传框架怎么避免重复开启线程
是这样的,你在线程中读取网络数据,如果网络中断了,就会抛出一系列的异常 这时候,你就要捕获这些异常做不同的提示 以下是一些网络连接中常见的异常 // 处理网络异常 public String ExceptionCode(Exception e) { if(e instanceof HttpException) { return contextworkFailure); // 网络异常 }else if (e instanceof SocketTimeoutException) { return contextworkError); // 网络异常 }else if (e instanceof JSONException) { return context.getString(R.string.json_error); //json格式转换异常 }else { return context.getString(R.string.canNotGetConnected); // 无法连接网络 } }已经封装好了,你直接调用就好了
㈨ android网络框架怎么调用
我们在做项目中一定少不了网络请求,现在很多公司的网络请求这块好多都是使用一些比较好的开源框架,我项目中使用的是volley,现在讲讲一些volley基本的使用,如果想要详细的了解就要去看它的源码了,现在贴代码讲一些它的使用了,
首先用一个类去封装下它的基本配置信息,以后需要变动的话,就直接在这里做修改,Android最好能把每个功能都独立出来,这样做修改的话 不会导致出现其他的bug,特别在有新员工进入到项目组中,分配任务沟通起来也省事,
ProtocolManager.Java 它是一个单例
关键代码
[java] view plain print?
private ProtocolManager(Context context){
initLoadBitmapConfig(context);
mQueue = Volley.newRequestQueue(context);
}
我们在调接口的时候 只需要这样:
[java] view plain print?
Map<String,String> param = new HashMap<String, String>();
param.put("checksum", 0+"");
㈩ android底层网络框架是怎么实现的
一个好用的网络底层框架可以很大的程度上方便自己的项目,我们下面要做的就是一个趁手的网络框架。
做一个网络框架我们首先要确定这个网络框架除了能够从网络上获取数据还需要哪些功能:
首先抛弃AsyncTask,自定义一套网络底层的封装框架。
设计一套适合自己App的缓存策略
设计一套假数据返回的机制,在网络请求API没有返回的时候,可以假装获取到了网络返回的数据。
封装用户cookie的逻辑。
其他的还好,可能有人对于第一步的那个抛弃AsyncTask有些疑问,就是为什么要抛弃啊,这个类这个好用,内部封装了那么多的方法。但是我们不能只看到这个的优点,这个类有个致命的缺点:不能灵活的控制内部的线程池。
我们都知道的是,线程池里面的每个线程都是API的调用请求,而AsyncTask中有没有暴漏出取消这些请求的方法,这个时候,如果我们从A界面调到B界面,那么在A界面调用的API请求,如果还没有返回,并不会被取消,对于一个频繁调用API请求的APP应用应用来说,一个界面调用的API可能超过十个,在网络不好的情况下,如果这个时候跳转到了其他界面,这个时候其他界面也会调用API,这个时候造成的情况就是这个界面的请求并不会显示数据,因为首页的请求还在排队,要等首页的请求完成之后你才可以调用,这个就是所谓的AsyncTask堵塞。
我刚工作的时候遇到一个情况就是,根据公司的情况写了一个统计用户交互数据的SDK,开始的使用时候就是这个AsyncTask类,结构我发现在APP中某一个界面的吊起特别的慢,数据加载也非常的慢,发现的原因是我写的这个SDK中的API请求调用超时,并且在超时的时候重复调用三次这个API。
网络请求的格式
网络请求两个方法POST和GET,我们一般把GET方法为请求数据,POST为修改数据。请求的方法格式也是相对有讲究的。
Request
所有的MobileApi都可以写作:http://www.xxx.com/aaaa.api的形式。
GET:对于GET方法我们可以将请求API写作http://www.xxx.com/aaaa.api K1=va1&K2=va2,形式,也就是说,把key-value这样的键值对存放在URL上,这样做的话会方便我们后面对数据进行缓存,另外要精良是GET的参数都是String,int这样的类型,方便缓存,解析。
POST:我们都知道看不见POST的请求数据,一般key-value这样的键值对存放在Form表单中,最后进行提交请求。POST经常会提交大量数据,所以有些键值对要定义成集合或复杂的自定义实例,这个时候我们就需要把这样的值转换为JSON字符串进行提交,有APP传递到API后,在将JSON字符串转换为对于的实体。
Response
服务器现在用的最多的是使用JSON作为api返回的结果,这里也是使用JSON。
一般情况下返回的json数据中要有以下数据:
首先一个是否调用api成功的参数,
另外一个错误类型的参数(这个参数可以是Int格式的参数,成功为0)
错误具体信息的参数,成功为“”
具体API返回的结果,失败为“”
所以我们定义一个Response实体类,作为JSON实体的最外层。
如果成功返回了数据,数据会存放在result字符按中,映射为Response实体的result属性。
如果上面返回的result是一种实体的集合,那么就要把result解析为相应的实体集合。
我们在前面看到我们把AsyncTask抛弃重新写一个扩展性强的,可以随时取消API请求网络底层,那么我们的这个网络底层的线程池使用的是什么:使用原生的ThreadPoolExecutor + Runnable + Handler
首先我们要把App所调用的所有的API接口放到一个类或者xml文件中去,我们这里放在xml文件里面去,当然要写出读取xml的类和函数:
其中key和url的值符合key-value键值,expires代表数据缓存的时间单位为毫秒,netType代表请求方式(POST和GET) ,mockClass代表的是返回假数据的类。
RemoteService和RequestCallback和RequestParameter
这三个类表示的是请求的服务,请求返回,请求参数,三个给APP调用的类。
其他的两个类在方法中调用:
context:表示上下文
key:即xml文件中的key
RequestParameter:请求携带的参数
callback:请求回调
forceUpdate:是否强制更新数据,忽略缓存
RequestMannager类是一个集合类,用于取消请求的。每次发起请求时,都会把为此创建的Request添加到RequestManager中,即RequestManager中保存了全部的request。
他是对ThreadPoolExecutor和ArrayBlockingQueue的简单封装,是一个线程池,每发起一次请求,这个线程池就会分配一个新的线程来执行该请求。
HttpRequest类,发起HTTP请求的地方,他事先了Runable,从而让DefaultThreadPool可以分配新的线程,所以所有的请求逻辑都在Runnable接口方法里:
在这个类中对于get请求接口,他会把传递来的数据,处理为相应的格式:http://www.xxx.com/aaaa.api K1=va1&K2=va2。对于Post格式的请求接口,他会把传递过来的数据转换为BasicNameValuePair的形式,并放在表单中提交。
需要注意的是,因为我们把每个HttpRequest都放在了子线程中执行,所以RequestCallback的回调不能直接操作UI线程的控件,所以这个时候Handler就可以用到了。使用这个就可以保证RequestCallback的回调在UI线程上,不会报错。