Android Retrofit用法详解

Retrofit与LoopBack实战
本文详细介绍如何使用Retrofit结合LoopBack实现RESTful API客户端开发。包括搭建LoopBack服务器、配置Retrofit依赖、定义Java实体类及接口、实现客户端访问等步骤。

原文出处于此,我想再也找不到如此详细的用法详解了,涵盖使用代码示例使用示例的视频课件

我这里仅仅只把课件展示出来,如果有需要看代码或者视频学习的小伙伴,可以自行点击。

原文作者在使用retrofit编写基本的client端代码之前,先使用LoopBack搭建一个用于测试的api server,这一步不太清楚的同学可以去LooBack官网查阅一下,视频里也是粗略的有提到而已。

那么以下就是原作的课件了,当然,有部分是我在过程中补充的一些我的笔记,看看就好:

利用LoopBack搭建好一个api server之后,我们会在浏览器中看到一个如下图所示的界面:

(由于原作的课件之中,这张截图始终无法显示,所以我猜测原作应该是想要把这张图放出来,给大家展示一下LoopBack搭建好一个api server是什么样子的,所以我去视频里把这张图截下来了,希望没有截错 ...)

在图中可以看到很多形式的api接口, 如POST GET PUT DELETE HEAD, 我们可以利用这些api测试我们android的代码。

现在,我们实现一个基本的rest api访问功能。

第零步,编写正式的代码前, 我们需要做一些准备工作。 首先,我们需要在项目中引入retrofit类库, 因为我是用android studio来开发,所以需要在主module的build.gradle文件中加入retrofit的依赖, 在dependencies节点中加入如下代码:

 compile 'com.squareup.retrofit:retrofit:1.9.0'

同步一下gradle,会发现在项目的External Libraries中已经存在retrofit的类库了。

我们还需要做的另外一个配置是在清单文件中加入网络访问的权限。

第一步, 我们需要实现一个和server端CoffeeShops Model相对应的java实体类, 我们取名为CoffeeShop, (理论上如果害怕麻烦的话,可以直接将java实体类与server端一一对应,但也可仅仅取出所需字段),代码如下:

public class CoffeeShop extends BaseHttpModel {
    public int id;
    public String name;
    public String brand;
    public String made_in;
}

我这里补充一个截图,server端CoffeeShops Model有如下字段:

BaseHttpModel类代码:

public class BaseHttpModel {
    //方便打印返回数据
    @Override
    public String toString() {
        return new Gson().toJson(this);
    }
}

第二步,我们需要写一个接口,这个接口里的方法和服务器端的api一一对应:

public interface LoopBackService {
    @POST("/CoffeeShops")
    void postCoffeeShop(@Body CoffeeShop coffeeShop, Callback<CoffeeShop> cb);


    @GET("/CoffeeShops")
    void getCoffeeShop(Callback<List<CoffeeShop>> cb);

    @PUT("/CoffeeShops")
    void putCoffeeShop(@Body CoffeeShop coffeeShop, Callback<CoffeeShop> cb);

    @DELETE("/CoffeeShops/{id}")
    void deleteCoffeeShop(@Path("id") int id, Callback<Object> cb);
}

第三步, 我们需要实现一个Client类, 这个类可以返回一个第二步接口的一个实例

public class RestClient {
    private static LoopBackService service;

    private RestClient() {};

    public static LoopBackService getService() {
        if (null == service) {
            service = new RestAdapter.Builder()
                    .setEndpoint(Config.API_HOST)
                    .setLogLevel(RestAdapter.LogLevel.FULL)
                    .build()
                    .create(LoopBackService.class);
        }
        return service;
    }
}

观察上面的代码,我们使用单例来保证程序中只存在一个service的实例, 这里并没有考虑线程安全,因为我觉得这里并不需要考虑子线程调用的问题。

好,到这里,一个基本的api访问的代码已经编写完毕, 剩下的工作就是使用我们上面三步的代码来访问api数据。

我们在LoopBackService接口里写了4个方法, 我们在界面上相对应的放置4个按钮,来分别实现访问这4个api的动作。

完整的代码示例,可自行下载查看。

 

 

乐播投屏是一款简单好用、功能强大的专业投屏软件,支持手机投屏电视、手机投电脑、电脑投电视等多种投屏方式。 多端兼容与跨网投屏:支持手机、平板、电脑等多种设备之间的自由组合投屏,且无需连接 WiFi,通过跨屏技术打破网络限制,扫一扫即可投屏。 广泛的应用支持:支持 10000+APP 投屏,包括综合视频、网盘与浏览器、美韩剧、斗鱼、虎牙等直播平台,还能将央视、湖南卫视等各大卫视的直播内容一键投屏。 高清流畅投屏体验:腾讯独家智能音画调校技术,支持 4K 高清画质、240Hz 超高帧率,低延迟不卡顿,能为用户提供更高清、流畅的视觉享受。 会议办公功能强大:拥有全球唯一的 “超级投屏空间”,扫码即投,无需安装。支持多人共享投屏、远程协作批注,PPT、Excel、视频等文件都能流畅展示,还具备企业级安全加密,保障会议资料不泄露。 多人互动功能:支持多人投屏,邀请好友加入投屏互动,远程也可加入。同时具备一屏多显、语音互动功能,支持多人连麦,实时语音交流。 文件支持全面:支持 PPT、PDF、Word、Excel 等办公文件,以及视频、图片等多种类型文件的投屏,还支持网盘直投,无需下载和转格式。 特色功能丰富:投屏时可同步录制投屏画面,部分版本还支持通过触控屏或电视端外接鼠标反控电脑,以及在投屏过程中用画笔实时标注等功能。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值