swagger简介

swagger是一个工具,用于自动生成web网站对外提供的服务接口文档,并且以web页面的形式进行展示。

那么我们为什么需要这个工具呢?这首先需要从web相关项目的开发模式说起。

web相关的项目,可以分为服务端的开发和客户的开发。客户端的形式一般有html页面,android,和其他一些形式。服务端提供webservice形式的接口,供客户端进行调用。

当服务端的开发和客户端的开发是由不同的团队完成的时候,需要两个团队首先约定好接口的定义。接口的定义一般是由开发服务端的团队来进行,把服务端提供的接口写成文档,交给客户端的开发人员,让他们按照文档中接口的定义,来调用服务端的服务程序。

问题在于,服务端提供的接口并不能一次完成,它是在开发过程中不断修改的。那么这就需要服务端的开发人员,在每次修改完接口之后,就要更新一次接口文档,然后把新版的文档发给客户端的开发人员,让他们按照新版的文档进行使用。

如果这个中间的过程存在滞后,特别是服务端和客户端的开发团队在两个城市的时候,那么就特别容易带来接口不匹配的问题。

swagger工具,就是为了解决这个问题而开发的。它本身是一些jar包,使用的时候需要把这些jar包加到服务端程序的编译路径里。服务接口的开发跟之前一样,需要增加的内容是,在每个需要对外提供服务的接口的上面加上一些注解,形如@param等,加上这些注解之后,swagger工具就能自动都把这些接口提取出来,并以网站的形式对外展现。

除了能够展现接口的定义之外,swagger工具还提供了对接口的单元测试功能,这个功能能够帮助客户端开发人员对接口的理解和使用。

使用swagger工具之后,对于服务端的开发人员来讲,就不需要再写接口文档了,他们只需要在对外服务接口上加上一些注解,就可以把这些接口展现给客户端的开发人员。接口定义修改了的时候,只需要同步维护这些注解,客户端人员看到的接口就会同步更新。因为维护这些注解是在代码级的,服务端的开发人员在修改代码的时候可以同步进行修改,几乎不耗费额外的精力。

而对于客户端的开发人员来讲,调用接口的时候,他们不需要再去查看接口文档了,而是直接查看由swagger工具提供的接口网站。这里提供的接口定义,比文档里面的更加准确,直接,更新及时。

总而言之,在web网站开发需要多团队协作的时候使用swagger工具,能够有效降低不同团队之间有关的接口定义的沟通成本,提高团队的开发效率。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 174,831评论 25 709
  • swagger 了解更多 一、简介 Swagger是一种REST APIs的简单但强大的表示方式,标准的,语言无关...
    阿琦zzz阅读 4,804评论 1 0
  • Swagger 是一款RESTFUL接口的文档在线自动生成+功能测试功能软件。本文简单介绍了在项目中集成swagg...
    GhostStories阅读 2,671评论 2 13
  • 凌晨1点。蓝喵辗转难眠。手机里那个熟悉的号码。拨通后又快速挂断。到了一定的年纪。我们都会给自己找各种台阶,厚重的盔...
    被狗叼走的棉花糖阅读 200评论 0 0
  • 《同读一本书 2016-06-01-074 》 (米娅快跑) 正文:"这样浅显的道理,做起来却很难,尤其对于那些...
    贠霞阅读 272评论 0 0