使用OkHttp的那些事儿(一)
来源:互联网 发布:旋风小子 知乎 编辑:程序博客网 时间:2024/05/10 09:40
OkHttp作为目前相当流行的网络请求框架,已经被Google官方认定,而且Google在官方的应用程序中也已经大量的使用。
网络上不乏大量有关于OkHttp的教程,本人才疏学浅,只得将OkHttp的基本使用方式在下面做一个整理。
这里使用 https://api.douban.com/v2/book/search?q=金瓶梅&tag=&start=0&count=1
作为接口调用API。
首先在AS中添加依赖: compile 'com.squareup.okhttp3:okhttp:3.6.0'
注意在清单文件中加入网络请求的权限。
GET请求的基本流程:
//首先创建请求的客户端对象 OkHttpClient client=new OkHttpClient(); //使用Request.Builder来创建请求对象 Request.Builder builder=new Request.Builder(); //指定使用GET请求,并且指定要请求的地址 Request request=builder.get().url("https://api.douban.com/v2/book/search?q=金瓶梅&tag=&start=0&count=1").build(); //将请求加入请求队列,将请求封装成Call对象 Call call=client.newCall(request); //使用异步的方式来得到请求的响应并且处理 call.enqueue(new Callback() { @Override public void onFailure(Call call, IOException e) { //请求失败 } @Override public void onResponse(Call call, final Response response) throws IOException { //请求成功 //此处非UI线程 runOnUiThread(new Runnable() { @Override public void run() { Toast.makeText(getApplicationContext(),response.body().toString(),Toast.LENGTH_SHORT).show(); } }); } });
上面是异步的请求URL然后得到响应,当然也可以同步的请求网络:
//将请求加入请求队列,将请求封装成Call对象 Call call=client.newCall(request); //使用同步的方式来得到响应 new Thread(){ @Override public void run() { super.run(); try { final Response response=call.execute(); } catch (IOException e) { e.printStackTrace(); } } }.start();
OK,上面的两种方式就是GET请求的基本流程.这里我们可以看到,无论通过哪一种网络请求方式,我们得到的最终结果就是Response这个响应对象,我们所请求的结果也都封装在这个Response对象中。
我们通过response.isSuccessful()
来判断得到的响应是否成功;
我们通过response.body()
来得到成功响应时候的响应体,
response.body().string(); //将响应的结果以字符串的形式返回 response.body().bytes(); //将响应的结果以字节数组的形式返回 response.body().byteStream(); //将响应的结果以字节流的形式返回 response.body().contentLength(); //得到响应内容的长度
除此之外,我们可以使用response.close();
来关闭响应释放资源的等等。
POST请求的基本流程:
OkHttpClient client=new OkHttpClient(); Request.Builder builder=new Request.Builder(); //post请求传递参数首先需要创建请求体: RequestBody requestBody=new FormBody.Builder().add("key1","value1") .add("key2","value2") .add("key3","value3") .add("key4","value4") .build(); Request request=builder.post(requestBody).url("xxxURL地址").build(); client.newCall(request).enqueue(new Callback() { @Override public void onFailure(Call call, IOException e) { } @Override public void onResponse(Call call, final Response response) throws IOException { runOnUiThread(new Runnable() { @Override public void run() { try { Toast.makeText(getApplicationContext(),response.body().string().toString(),Toast.LENGTH_SHORT).show(); } catch (IOException e) { e.printStackTrace(); } } }); } });
由于POST请求时,参数是封装在请求体中的,因此这里我们使用RequestBody来封装请求参数。
0 0
- 使用OkHttp的那些事儿(一)
- 使用OkHttp的那些事儿(二)
- 使用OkHttp的那些事儿(三)
- 使用OkHttp的那些事儿(四)
- Volley配置OkHttp的那些事儿
- Handler使用的那些事儿
- 【邦客】创业的那些事儿[一]
- 【邦客】创业的那些事儿[一]
- 【邦客】创业的那些事儿[一]
- 嵌入式开发的那些事儿(一)
- 【邦客】创业的那些事儿[一]
- 【邦客】创业的那些事儿[一]
- 笔试的那些事儿(一)
- 读研的那些事儿(一)
- 架构的那些事儿一总论
- os的那些事儿(一)
- Servlet&JSP的那些事儿(一)
- 网络编程 TCP 的那些事儿一
- BZOJ 4198([Noi2015]荷马史诗-k叉哈夫曼树)
- linux vim配置
- iOS-NSUndoManager与怎样弄崩微信
- 方差分析
- tomcat启动时出现异常Exception loading sessions from persistent storage
- 使用OkHttp的那些事儿(一)
- 【学习总结】进程
- C++杂记
- Grand Central Dispatch(GCD)详解
- 《MySQL必知必会》学习笔记十三(存储过程)------掌握部分
- Mysql创建表不成功
- SpringMVC异常处理以及web错误页面处理
- 51nod-斐波那契表示(找规律)
- CodeBlocks常用操作快捷键