OpenAPI 简介
本文分享自天翼云开发者社区《OpenAPI 简介》,作者:蔡****钊
一、什么是open API
API的全称是应用编程接口(Application Programming Interface),而所谓的open API其实就是一种面向客户的开放接口能力,而对应的客户,从我们以往常规认知的个人产品直接使用用户,变为技术用户。正如很多SaaS是提供具体的某个直接可使用的服务或者能力,open API则是将产品接口化提供类似PaaS类的技术能力。
二、常见的open API能力
你也许觉得open API的能力离我们很远、你也许觉得我们手机上使用的很多应用就是当前使用app 对应的厂商提供的。实际上,他们只是调用底层平台提供的开放平台能力做接入,并实现的。如:
1.地图类
说起地图,相信大家生活中肯定都离不开。比如常用的高德地图做导航,这是最直观的应用。当渗透如我们生活方方面面的还有比如各类打车软件、外卖平台、甚至基于地图的二手交易平台、交友平台等等。这类平台本身不具备地图能力,都是通过调用第三方平台提供的地图能力,对地图进行展示、基于地图能力对车辆所在点、路线等进行叠加的渲染。甚至我们熟知的谷歌地图,也开放了丰富的地图能力。
2.搜索类
搜索类国内最有名的无非是百度、搜狗等平台。他们提供的搜索接口,可以帮助平台站点建立搜索功能,或者对搜索结果进行排序封装。国外典型的例子如google search API, yahoo search API等。
使用方也有如小红书,知乎等,早期可能大家没有搜索能力都会去调用搜索开放平台能力,但平台做大了也可能自己搭建搜索团队。
3.文字资讯类
RSS订阅接口可以成为几乎所有文字资讯类服务的标准API,如各类资讯网站和论坛等。但随着订阅类型的产品逐步减少,这类产品和能力也逐渐减少。但也还有许多专有的API提供专有的文字资讯类服务,例如twitter的API、craigslist的API、豆瓣的API等。
4.用户及关系类
国内最大的社交平台不外乎我们熟知的两大社交软件。其提供的各类分享和好友关系能力,也让很多营销工具、社交玩法有了基础根基。也正是有这些开放平台,让此两个社交软件成为各种涉及大众吃喝玩乐方方面面的应用,都能在这两棵大树上生根发芽,从而也让这两棵大树的根基更加地稳固。
5.电子商务类
此类网站主要围绕企业信息和商品信息展开设计。开放此类接口地目的是为了让外部平台使用获利,从而提高电商网站的用户粘性和销量。最典型的有京东的京粉平台,拼多多的多多进宝。这两个平台提供类似“淘客”的分销分佣模式。当内容或者社交平台有自己的用户时,可以通过电商平台的接口调用展示商品,和提供跳转购买链路。当普通用户通过他们的渠道购买后,平台就能获得电商网站的分佣激励。
6.注册类
还有一类时所有人绕不开但却很不起眼的能力,就是最基础的登录注册能力。包括运营商提供的短信验证码服务,真人图形校验,实名验证等等。
三、挑战
挑战1:选择API设计模式
当你在考虑单个产品的API表现形式时,首先会选择一种具体的API风格,常见的有Remote Procedure Call和 Rest-Oriented Architecture两种模式。不同模式选型意味着后续基础的不同。是最基础的能力决策。
挑战2:面向资源设计
特别对于使用api来访问云服务的过程,本质上是对某种云资源执行特定的操作来完成业务动作。关键在于:
一是要有比较统一的资源模式,才便于进行特定的鉴权。二是要明确资源关系,便于关联鉴权。
挑战3:设计风格
包括如API名称、参数名、属性名、数据格式、错误码等等,都决定了其对外用户使用的风格。要保证命名规范统一、对外易于理解。
挑战4:服务端容错
容错对于业务来说非常重要。你永远无法预测到业务上下游会出现什么情况,对于边界或者异常的场景,都要能做到容错处理,保证业务不会奔溃。
挑战5:版本管理
对于版本迭代中,最最重要的是平滑切换。无论是对老业务接口的兼容,还是新接入的业务,都要能做到兼容平滑。否则对老客户的伤害可能会直接导致我们的业务口碑崩坏。
当然,在做开放平台API时,会遇到更多挑战。但作为to B 的业务,一定要有最强的服务意识,本着给用户提供更优质服务的心,相信就能应对各类挑战!
OpenAPI 简介的更多相关文章
- Kubernetes官方java客户端之六:OpenAPI基本操作
欢迎访问我的GitHub https://github.com/zq2599/blog_demos 内容:所有原创文章分类汇总及配套源码,涉及Java.Docker.Kubernetes.DevOPS ...
- 云计算平台简介(App Engine)
云计算平台简介(App Engine) 1 简介 App Engine: 应用程序引擎,是托管网络应用程序的云计算平台. 1.1 什么是云 云计算通常简称为“云”,是一种通过 Inter ...
- 阿里云短信验证_基于阿里云OpenAPI实现
阿里云短信服务 背景简介: 短信验证以及短信通知,目前已经应用的非常广泛,最近因项目需要,需要将原来的短信接口换成阿里云的的短信服务,原项目集成的短信服务能够实现短信的发送以及短信的验证整个过程,简单 ...
- 搭建个人OpenAPI
简介 OpenAPI Open API 即开放 API,也称开放平台. 所谓的开放 API(OpenAPI)是服务型网站常见的一种应用,网站的服务商将自己的网站服务封装成一系列 API(Applica ...
- 使用Dapr和.NET 6.0进行微服务实战:Dapr简介
大家好,我是张飞洪,感谢您的阅读,我会不定期和你分享学习心得,希望我的文章能成为你成长路上的垫脚石,让我们一起精进. 本文是<使用Dapr和.NET 6.0进行微服务实战>的第2篇Dapr ...
- ASP.NET Core 1.1 简介
ASP.NET Core 1.1 于2016年11月16日发布.这个版本包括许多伟大的新功能以及许多错误修复和一般的增强.这个版本包含了多个新的中间件组件.针对Windows的WebListener服 ...
- MVVM模式和在WPF中的实现(一)MVVM模式简介
MVVM模式解析和在WPF中的实现(一) MVVM模式简介 系列目录: MVVM模式解析和在WPF中的实现(一)MVVM模式简介 MVVM模式解析和在WPF中的实现(二)数据绑定 MVVM模式解析和在 ...
- Cassandra简介
在前面的一篇文章<图形数据库Neo4J简介>中,我们介绍了一种非常流行的图形数据库Neo4J的使用方法.而在本文中,我们将对另外一种类型的NoSQL数据库——Cassandra进行简单地介 ...
- REST简介
一说到REST,我想大家的第一反应就是“啊,就是那种前后台通信方式.”但是在要求详细讲述它所提出的各个约束,以及如何开始搭建REST服务时,却很少有人能够清晰地说出它到底是什么,需要遵守什么样的准则. ...
- Microservice架构模式简介
在2014年,Sam Newman,Martin Fowler在ThoughtWorks的一位同事,出版了一本新书<Building Microservices>.该书描述了如何按照Mic ...
随机推荐
- vue前端分页多条件搜索
vue前端分页多条件搜索 fliterData() { if (this.query_syscode || this.query_version || this.query_group || Stri ...
- golang之errors包
errors包常用方法 func Unwrap(err error) error // 获得err包含下一层错误 func Is(err, target error) bool // 判断err是否包 ...
- Yii2之model
记录model常用方法 between: $model->andFilterWhere(['between','apply_time',$startTime,$endTime])
- 第四届河南省 CCPC 大学生程序设计竞赛
F-集合之和 规定集合A和集合B的加法运算:\(A+B={x+y|x∈A,y∈B}\),设有限数集A中的元素个数为|A|,现给定n,请你构造集合A使得\(|A+A|=n\),如果A不存在,输出-1 题 ...
- javase学习文档
javase学习文档(更新) javase 学习文档已更新 查看地址:https://lib.stazxr.cn/codenotes/java/javase/
- Spring AOP基础、快速入门
介绍 AOP,面向切面编程,作为面向对象的一种补充,将公共逻辑(事务管理.日志.缓存.权限控制.限流等)封装成切面,跟业务代码进行分离,可以减少系统的重复代码和降低模块之间的耦合度.切面就是那些与业务 ...
- 初识RPA以及简单的RPA项目——微信群发机器人
一.RPA的认识和理解 RPA(Robotic Process Automation)即是机器人流程自动化,简称RPA,是一种自动化技术,可以帮助组织实现业务流程的自动化执行,提高效率和准确性.按我的 ...
- 一比一还原axios源码(七)—— 取消功能
按照惯例,我们先来看下官方的例子: 你可以通过axios的CancelToken工厂函数,生成一个source,然后把这个对象作为参数传递给axios,最后,需要取消的时候调用source的cance ...
- Shiro-BasicHttpAuthenticationFilter 鉴权过滤器的使用方式
它的作用是用来根据路径匹配结果,调用相应过滤器 onPreHandle 这里是正在的执行逻辑,之前的都是判断,它返回了两个方法: isAccessAllowed() onAccessDenied() ...
- sublime text 4 安装(含激活码)
一.下载步骤 官网地址:Sublime Text - the sophisticated text editor for code, markup and prose windows下载链接:Than ...