API网关具备自动生成多语言SDK的能力

API网关为了实现客户端和服务器端之间的安全通讯,设计了全套的签名策略,只有携带通过复杂的签名算法的签名请求头的请求才会被API网关转发给后端服务器,否则请求会被API网关拒绝。这个连接是API签名算法的具体说明:https://help.aliyun.com/document_detail/29475.html,相信大家看到签名算法的介绍,会发现该签名算法有一定的复杂度,实现起来需要花费不少的时间,还需要和网关联调,有一定的工作量。

作为API网关的用户,要想正确得使用API网关的各项能力,就需要自己在客户端实现API网关定义签名算法。还有一个选项就是,使用API网关官方提供的SDK。本文不是给大家介绍签名算法的,而是给大家介绍API网关的SDK生成能力。

首先,API网关按照使用用户的不同分别给API提供者(Provider)和API使用者(Consumer)提供了不同的SDK生成入口。对于Provider而言,他们可以在API网关自动生成他们拥有的Group下的所有线上API的调用SDK。Consumer则可以在API网关下载基于应用(App)维度的SDK,比如consumer的一个应用(App)购买了并被授权拥有A,B,C三个API,那么consumer可以在API网关一键生成A,B,C三个API的调用SDK,不管这三个接口是否属于同一个API供应商,都能在一个SDK包能下载下来。

下面是API网关为API提供者(Provider)提供的SDK生成页面,左边API网关->开放API->SDK/文档自动生成是页面的入口。我们可以看到,Provider可以选择Region和Group来生成指定语言的SDK。

API网关具备自动生成多语言SDK的能力

下面是API网关为API使用者(Consumer)提供的SDK生成页面,左边API网关->调用API->已授权API的SDK 是页面的入口。我们可以看到,Consumer可以选择指定应用(App)来生成指定语言的SDK。

API网关具备自动生成多语言SDK的能力

API网关目前提供iOS,Android两种移动客户端的SDK的自动生成功能,基本覆盖了绝大部分移动客户端。API网关还提供大众语言Java的SDK的自动生成功能。后继,我们还会陆续推出PHP,Python,.NET,Node.js等主流语言的SDK的自动生成能力。

下面我们介绍下API网关自动生成的SDK压缩包内的文件结构,以Android为例,其他语言的都比较类似:

  • SDK文件夹

    • sdk

      • Demo_{{groupName}}.java Api调用示例
      • SyncApiClient_{{groupName}}.java 对应Group的所有API同步接口实现,直接调用本类实现Api调用
      • AsyncApiClient_{{groupName}}.java 对应Group的所有API接口异步实现,直接调用本类实现Api调用
      • AppConfigurationInitializer.java APP秘钥配置类,使用API调用之后需要先配置本类
    • lib

      • alibaba-cloudapi-sdk-core-1.0.1.jar sdk的core包,实现底层通信
    • src sdk文件夹中使用的alibaba-cloudapi-sdk-core-1.0.1.jar的源码

      • CloudApiSdk.java SDK处理HTTP请求的类
      • AppConfiguration.java SDK配置类
      • SignUtil.java 签名的实现类
      • HttpConstant.java SDK用到的Http常量
      • SDKConstant.java SDK内部用到的常量
      • CallMethod.java 同步、异步枚举
    • doc

      • ApiDocument_{{groupName}}.md 对应Group的API接口文档
    • Readme.md SDK使用指南
    • LICENSE 版权许可说明

本SDK非常容易使用,完全按照Readme配置后以后,就可以像SDK的Demo那样调用API接口了,下面是一个非常简单的调用示例:

public static void testPathSyncTest(){
        SyncApiClient_GroupName.testPath("test" , "test" , "test" , new Callback() {
            @Override
            public void onFailure(Call call, IOException e) {
                String result = e.getMessage();
            }

            @Override
            public void onResponse(Call call, Response response) throws IOException {
                String result= getResultString(response);
            }
        });
    }

SDK压缩包中有所有涉及的API的MD格式的相关文档,包括API描述信息,参数信息,请求信息及应答、错误码等所有信息,下面是一个截图:

API网关具备自动生成多语言SDK的能力

如果在使用中遇到棘手的问题,请加入我们官方旺旺群来找我们,群号:1640106170

上一篇:API网关的iOS SDK已经支持 IPV6


下一篇:重启Windows系统