Retrofit2使用(很是简洁易懂)

一、什么是Retrofit框架?

它是Square公司开发的如今很是流行的网络框架,因此咱们在导入它的包的时候均可以看到这个公司的名字,目前的版本是2。css

特色:html

性能好,处理快,使用简单,Retrofit 是安卓上最流行的HTTP Client库之一
使用REST API设计风格
支持 NIO(new i/o)
默认使用OKHttp处理网络请求,我以为能够当作是OKHttp的加强。
默认使用Gson解析java

进入正题。android

===================================git

二、如何使用?

步骤:

一、导包

compile ‘com.squareup.retrofit2:retrofit:2.0.0-beta4’
同步之后,在External Libraries中会增长:github

retrofit-2.0.0-beta4
okhttp-3.0.1
okio-1.6.0web

compile ‘com.squareup.retrofit2:converter-gson:2.0.0-beta4’json

同步之后,在External Libraries中会增长:api

retrofit-2.0.0-beta4
okhttp-3.0.1
okio-1.6.0
gson-2.4
converter-gson-2.0.0-beta4网络

这些包都是Squareup公司开发的。
因此咱们只用compile ‘com.squareup.retrofit2:converter-gson:2.0.0-beta4’也是能够的。

二、了解Retrofit2中的网络访问经常使用注解接口,其实这些接口都是在retrofit2.http这个包下面的

一、@GET GET网络请求方式
二、@POST POST网络请求方式
三、@Headers() 头信息参数
四、@Path() 路径参数,替换url地址中 { } 所括的部分
五、@Query() 查询参数,将在url地址中追加相似“page=1”的字符串,造成提交给服务端的请求参数
六、@QueryMap 查询参数集合,将在url地址中追加相似
“type=text&username=abc&password=123”的字符串
七、@FormUrlEncoded 对表单域中填写的内容进行编码处理,避免乱码
八、@Field() 指定form表单域中每一个空间的额name以及相应的数值
九、@FieldMap 表单域集合
十、@Multipart Post提交分块请求,若是上传文件,必须指定Multipart
十一、@Body Post提交分块请求

三、代码步骤:

一、定义一个接口(封装URL地址和数据请求)
二、实例化Retrofit
三、经过Retrofit实例建立接口服务对象
四、接口服务对象调用接口中方法,得到Call对象
五、Call对象执行请求(异步、同步请求)

测试Url:
https://api.github.com/users/basil2style

其中https://api.github.com/users/是BASE_URL,也就是基础地址,basil2style是GET的参数,若是访问成功会返回给咱们一个json字符串:

{
  "login": "basil2style",
  "id": 1285344,
  "avatar_url": "https://avatars.githubusercontent.com/u/1285344?v=3",
  "gravatar_id": "",
  "url": "https://api.github.com/users/basil2style",
  "html_url": "https://github.com/basil2style",
  "followers_url": "https://api.github.com/users/basil2style/followers",
  "following_url": "https://api.github.com/users/basil2style/following{/other_user}",
  "gists_url": "https://api.github.com/users/basil2style/gists{/gist_id}",
  "starred_url": "https://api.github.com/users/basil2style/starred{/owner}{/repo}",
  "subscriptions_url": "https://api.github.com/users/basil2style/subscriptions",
  "organizations_url": "https://api.github.com/users/basil2style/orgs",
  "repos_url": "https://api.github.com/users/basil2style/repos",
  "events_url": "https://api.github.com/users/basil2style/events{/privacy}",
  "received_events_url": "https://api.github.com/users/basil2style/received_events",
  "type": "User",
  "site_admin": false,
  "name": "Basil",
  "company": "MakeInfo",
  "blog": "http://www.themakeinfo.com",
  "location": "Peterborough,ON,Canada",
  "email": "basiltalias92@gmail.com",
  "hireable": true,
  "bio": null,
  "public_repos": 45,
  "public_gists": 4,
  "followers": 52,
  "following": 145,
  "created_at": "2011-12-26T00:17:22Z",
  "updated_at": "2016-06-23T20:22:05Z" }

好,按步骤开始写代码

一、定义一个接口(封装URL地址和数据请求)
RequestServices.java

package com.example.eventbus.retrofittest;

import okhttp3.ResponseBody;
import retrofit2.Call;
import retrofit2.http.GET;

/** * Created by LHD on 2016/6/25. */
public interface RequestServices {
    //请求方式为GET,参数为basil2style,由于没有变量因此下面getString方法也不须要参数
    @GET("basil2style") 
    //定义返回的方法,返回的响应体使用了ResponseBody
    Call<ResponseBody> getString();
}

咱们一般把基础地址都放在一个类里,方便调用
Constant.java

package com.example.eventbus.retrofittest;

/** * Created by LHD on 2016/6/25. */
public class Constant {
    //baseurl
    public final static String URL_BASE = "https://api.github.com/users/";
}

二、实例化Retrofit

//获取Retrofit对象,设置地址
        Retrofit retrofit = new Retrofit.Builder()
                .baseUrl(Constant.URL_BASE)
                .build();

三、经过Retrofit实例建立接口服务对象

RequestServices requestServices = retrofit.create(RequestServices.class);

四、接口服务对象调用接口中方法,得到Call对象

Call<ResponseBody> call = requestServices.getString();

五、Call对象执行请求(异步、同步请求)

call.enqueue(new Callback<ResponseBody>() {
            @Override
            public void onResponse(Call<ResponseBody> call, Response<ResponseBody> response) {
               if (response.isSuccess()){
                   try {
                       Log.i("LHD",response.body().toString());
                       //返回的结果保存在response.body()中
                       String result = response.body().string();
                       //onResponse方法是运行在主线程也就是UI线程的,因此咱们能够在这里
                       //直接更新UI
                       textView.setText(result);
                   } catch (IOException e) {
                       e.printStackTrace();
                   }
               }
            }

            @Override
            public void onFailure(Call<ResponseBody> call, Throwable t) {
                Log.i("LHD","访问失败");
            }
        });

所有代码:
MainActivity.java

package com.example.eventbus.retrofittest;

import android.content.Context;
import android.os.Bundle;
import android.support.v7.app.AppCompatActivity;
import android.util.Log;
import android.widget.TextView;

import java.io.IOException;

import okhttp3.ResponseBody;
import retrofit2.Call;
import retrofit2.Callback;
import retrofit2.Response;
import retrofit2.Retrofit;

public class MainActivity extends AppCompatActivity {

    private Context mContext = this;
    private TextView textView;
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        initView();
        initRetrofit();
    }
    private void initView(){
        textView = (TextView) findViewById(R.id.tv_retrofit);
    }
    private void initRetrofit(){
        //获取Retrofit对象,设置地址
        Retrofit retrofit = new Retrofit.Builder()
                .baseUrl(Constant.URL_BASE)
                .build();
        Log.i("LHD","1");
        RequestServices requestServices = retrofit.create(RequestServices.class);
        Call<ResponseBody> call = requestServices.getString();
        call.enqueue(new Callback<ResponseBody>() {
            @Override
            public void onResponse(Call<ResponseBody> call, Response<ResponseBody> response) {
               if (response.isSuccess()){
                   try {
                       Log.i("LHD",response.body().toString());
                       //返回的结果保存在response.body()中
                       String result = response.body().string();
                       //onResponse方法是运行在主线程也就是UI线程的,因此咱们能够在这里
                       //直接更新UI
                       textView.setText(result);
                   } catch (IOException e) {
                       e.printStackTrace();
                   }
               }
            }

            @Override
            public void onFailure(Call<ResponseBody> call, Throwable t) {
                Log.i("LHD","访问失败");
            }
        });

    }
}

咱们的代码就是将请求的返回值显示在一个textview上,最后的效果如图所示:

返回

Retrofit2中GET请求的写法

一、GET请求,方法中无参数

@GET(“article/page=1”)//并非所有的Url地址,这个地址会和BaseUrl一块儿组成一个新的地址。组合的时候要当心。
Call<ResponseBody> getString(); //这个方法名字是自定义的,由于基本地址里没有变量,因此咱们的自定义方法里也没有参数,其实这个方法的参数就是要添加到这个地址里的参数。
//ResponseBody是响应体

二、GET请求,方法中指定@Path参数和@Query参数

@Path用于替换url地址中{和}所括的部分。
@Query将在url地址中追加相似“page=1”的字符串,造成提交给服务端的请求参数

@GET(article/list/{type}?)
Call<QiushiModel>getList(
@Path('type')String type,
@Query('page')int page
);

三、GET请求,提交表单数据。方法中定义@QueryMap参数。

@QueryMap参数将在url地址中追加相似 “type=text&count=30&page=1”的字符串。
@GET("MyWeb/RegServlet")
Call<ResponseBody>getKey(@QueryMap Map<String,String>map);

四、GET请求,方法中无参数。但在@Url里定义完整URL路径,这种状况下BaseUrl会被忽略。

@GET("https://ss1.bdstatic.com/70cFvXSh_Q1YnxGkpoWK1HF6hhy/it/u=2299165671,2554860548&fm=116&gp=0.jpg");
Call<ResponsBody>getData();

这就是最简单的retrofit网络访问的过程啦。下一篇会更深刻的讲解,POST请求,获取网络图片,使用Gson解析返回的json文件等等。

demo下载:retrofit2+rxjava+okhttp使用demo。-CSDN下载
http://download.csdn.net/download/baidu_31093133/9696239