Android 经典笔记之八:网络请求数据基础介绍
阅读原文时间:2021年04月20日阅读:1

关于网络请求数据总结

目录介绍
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一下,谢谢!当然也欢迎提出建议,万事起于忽微,量变引起质变!

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请求

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 缓存机制逻辑图

其他说明