关于网络请求数据总结
目录介绍
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 缓存机制逻辑图
好消息
- 博客笔记大汇总【16年3月到至今】,包括Java基础及深入知识点,Android技术博客,Python学习笔记等等,还包括平时开发中遇到的bug汇总,当然也在工作之余收集了大量的面试题,长期更新维护并且修正,持续完善……开源的文件是markdown格式的!同时也开源了生活博客,从12年起,积累共计47篇[近20万字],转载请注明出处,谢谢!
- 链接地址:https://github.com/yangchong211/YCBlogs
- 如果觉得好,可以star一下,谢谢!当然也欢迎提出建议,万事起于忽微,量变引起质变!
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
- 甚至使用路由
http://xxxx.xx.com/xxx/value1/value2/value3
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 其他区别
- 因为url是存在于请求行中的。 所以Get与Post区别本质就是参数是放在请求行中还是放在请求体中。
3.4 网络心声
- Get是明文,Post隐藏
移动端不是浏览器,不用https全都是明文。
Get传递数据上限XXX
胡说。有限制的是浏览器中的url长度,不是Http协议,移动端请求无影响。Http服务器部分有限制的设置一下即可。
4.Http响应方式
- 请求是键值对,但返回数据我们常用Json。
- 对于内存中的结构数据,肯定要用数据描述语言将对象序列化成文本,再用Http传递,接收端并从文本还原成结构数据。
- 对象(服务器)<-->文本(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 缓存机制逻辑图
其他说明
- 知乎:https://www.zhihu.com/people/yang-chong-69-24/pins/posts
- 领英:https://www.linkedin.com/in/chong-yang-049216146/
- 简书:http://www.jianshu.com/u/b7b2c6ed9284
- csdn:http://my.csdn.net/m0_37700275
- 网易博客:http://yangchong211.blog.163.com/
- 新浪博客:http://blog.sina.com.cn/786041010yc
- github:https://github.com/yangchong211
- 喜马拉雅听书:http://www.ximalaya.com/zhubo/71989305/
- 脉脉:yc930211
- 360图书馆:http://www.360doc.com/myfiles.aspx
- 开源中国:https://my.oschina.net/zbj1618/blog
- 泡在网上的日子:http://www.jcodecraeer.com/member/content_list.php?channelid=1
- 邮箱:yangchong211@163.com
- 阿里云博客:https://yq.aliyun.com/users/article?spm=5176.100239.headeruserinfo.3.dT4bcV