关于网络请求数据总结
目录介绍
1.Http请求与响应
1.1 Http请求包的结构
1.2 HTTP响应包结构
2.Http请求方式
3.Get和Post的比较
3.1 get请求
3.2 post请求
3.3 其他区别
3.4 网络心声
4.Http响应方式
5.同步和异步
6.Http缓存机制讲解
6.1 request请求字段含义
6.2 response响应字段含义
6.3 缓存机制逻辑图
0.本人写的综合案例
案例
说明及截图
模块:新闻,音乐,视频,图片,唐诗宋词,快递,天气,记事本,阅读器等等
接口:七牛,阿里云,天行,干货集中营,极速数据,追书神器等等
1.Http请求与响应
一次请求就是向目标服务器发送一串文本。什么样的文本?有下面结构的文本。
1.1 HTTP请求包结构
例子:
POST /meme.php/home/user/login HTTP/1.1
Host: 114.215.86.90
Cache-Control: no-cache
Postman-Token: bd243d6b-da03-902f-0a2c-8e9377f6f6ed
Content-Type: application/x-www-form-urlencoded
tel=13637829200&password=123456
请求了就会收到响应包(如果对面存在HTTP服务器)
1.2 HTTP响应包结构
例子:
HTTP/1.1 200 OK
Date: Sat, 02 Jan 2016 13:20:55 GMT
Server: Apache/2.4.6 (CentOS) PHP/5.6.14
X-Powered-By: PHP/5.6.14
Content-Length: 78
Keep-Alive: timeout=5, max=100 Connection: Keep-Alive
Content-Type: application/json; charset=utf-8
{"status":202,"info":"\u6b64\u7528\u6237\u4e0d\u5b58\u5728\uff01","data":null}
2.Http请求方式
3.Get和Post的比较区别
3.1 get请求
在url中填写参数
http://xxxx.xx.com/xx.php?params1=value1¶ms2=value2
https://api.douban.com/v2/book/search?tag=文学&start=0&count=30
甚至使用路由
3.2 post请求
参数是经过编码放在请求体中的。 编码包括:
x-www-form-urlencoded
form-data
x-www-form-urlencoded`的编码方式是这样:
tel=13637829200&password=123456
form-data`的编码方式是这样:
----WebKitFormBoundary7MA4YWxkTrZu0gW
Content-Disposition: form-data; name="tel"
13637829200
----WebKitFormBoundary7MA4YWxkTrZu0gW
Content-Disposition: form-data; name="password"
123456
----WebKitFormBoundary7MA4YWxkTrZu0gW
3.3 其他区别
3.4 网络心声
移动端不是浏览器,不用https全都是明文。
Get传递数据上限XXX
胡说。有限制的是浏览器中的url长度,不是Http协议,移动端请求无影响。Http服务器部分有限制的设置一下即可。
4.Http响应方式
5.同步和异步的比较
这2个概念仅存在于多线程编程中。
Android中默认只有一个主线程,也叫UI线程
因为View绘制只能在这个线程内进行。所以如果你阻塞了(某些操作使这个线程在此处运行了N秒)这个线程,这期间View绘制将不能进行,UI就会卡。所以要极力避免在UI线程进行耗时操作。网络请求是一个典型耗时操作。
5.1同步写的方式:
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
NetUtils.get("http://www.baidu.com");//这行代码将执行几百毫秒
}
这就是同步方式。直接耗时操作阻塞线程直到数据接收完毕然后返回。Android不允许的。会卡死
5.2异步写的方式:
//在主线程new的Handler,就会在主线程进行后续处理。
private Handler handler = new Handler();
private TextView textView;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
textView = (TextView) findViewById(R.id.text);
new Thread(new Runnable() {
@Override
public void run() {
//从网络获取数据
final String response = NetUtils.get("http://www.baidu.com");
//向Handler发送处理操作
handler.post(new Runnable() {
@Override
public void run() {
//在UI线程更新UI
textView.setText(response);
}
});
}
}).start();
}
在子线程进行耗时操作,完成后通过Handler将更新UI的操作发送到主线程执行。这就叫异步。
抽取写法
**记住: 每次都new Thread,new Handler消耗过大 **
public class AsynNetUtils {
public interface Callback{
void onResponse(String response);
}
public static void get(final String url, final Callback callback){
final Handler handler = new Handler();
new Thread(new Runnable() {
@Override
public void run() {
final String response = NetUtils.get(url);
handler.post(new Runnable() {
@Override
public void run() {
callback.onResponse(response);
}
});
}
}).start();
}
public static void post(final String url, final String content, final Callback callback){
final Handler handler = new Handler();
new Thread(new Runnable() {
@Override
public void run() {
final String response = NetUtils.post(url,content);
handler.post(new Runnable() {
@Override
public void run() {
callback.onResponse(response);
}
});
}
}).start();
}
}
这个直接调用工具类
private TextView textView;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
textView = (TextView) findViewById(R.id.webview);
AsynNetUtils.get("http://www.baidu.com", new AsynNetUtils.Callback() {
@Override
public void onResponse(String response) {
textView.setText(response);
}
});
6.Http缓存机制讲解
缓存对于移动端是非常重要的存在。
减少请求次数,减小服务器压力.
缓存一般由服务器控制(通过某些方式可以本地控制缓存,比如向过滤器添加缓存控制信息)。通过在请求头添加下面几个字端:
6.1 request请求字段含义
6.2 response响应字段含义
6.3 缓存机制逻辑图
其他说明
手机扫一扫
移动阅读更方便
你可能感兴趣的文章