在springcloud项目中使用eureka,需要服务注册中心(即下面例子中的swagger-demo-server)和服务提供者(swagger-demo-consumer),同时服务的提供者之间可以相互调用,从而实现分布式架构。
Swagger 是一个用于生成、描述、调用和可视化 RESTful 风格的 Web 服务,能够实时同步api与文档,避免接口改动而文档未及时更新而产生的问题。
一、创建服务注册中心
file-->new-->other-->spring starterproject
data:image/s3,"s3://crabby-images/f44d5/f44d5be4e0a2ab8fa5c56c8cdc8e520bd02a4d5d" alt=""
选择web和eureka server构建项目,此时自动生成的pom中已添加依赖注册中心的依赖,或者是不选择,等项目生成完毕后再手动添加依赖
data:image/s3,"s3://crabby-images/0142f/0142f2c7de940ffc2a88478dd82319c146edecac" alt=""
1.配置文件 application.properties
data:image/s3,"s3://crabby-images/d28bf/d28bf7a367ca99a0e245f0c815b291f79f5cc2c6" alt=""
2.在启动类上加注解@EnableEurekaServer,表示它是一个注册中心
data:image/s3,"s3://crabby-images/9e081/9e081cbf647dd47ee1d12d9b69bb065b9d3bb8c8" alt=""
二、创建服务提供者
1.与注册中心的创建方式一样,此时是注意是服务端选择eureka discovery,生成的pom包括
data:image/s3,"s3://crabby-images/c206d/c206dd946128547eff75c66d6dc5bb361fd0e80c" alt=""
2.在pom中添加mybati和swagger相关的依赖
data:image/s3,"s3://crabby-images/aaf01/aaf016c0c83c46d9a9458a1ee77f943d0b68119d" alt=""
3.在启动类上增加注释@EnableEurekaClient,表示提供服务
4.在配置文件application.properties配置
data:image/s3,"s3://crabby-images/a1d44/a1d44c1aac69b9813112869903d2933ba6975af7" alt=""
5.建包,结构如下
data:image/s3,"s3://crabby-images/f6c23/f6c23c14289cbb5ebca3b96be524b2c46165898f" alt=""
6.新建对应controller service dao dto
data:image/s3,"s3://crabby-images/abd36/abd367b3bad1a2215551f476f26a1266d30dcf12" alt=""
data:image/s3,"s3://crabby-images/08d14/08d1468ce6c1ec2c1b9f7e03b79d904b58a0042d" alt=""
data:image/s3,"s3://crabby-images/62f47/62f479e1603b9c4b75ce2ddc2d2c0ba2aae870d6" alt=""
data:image/s3,"s3://crabby-images/eb5e2/eb5e26c9ee9bb5a93e1c6f1fe642f8cf4f9e3b2c" alt=""
7.配置文件添加mybatis相关的配置
data:image/s3,"s3://crabby-images/08f38/08f38aa7cb813a001ac983985f7e1324b079b184" alt=""
8.在启动类上添加注解@MapperScan("org.crx.swagger.dao"),扫描mapper
data:image/s3,"s3://crabby-images/c5d56/c5d5613ee8fd11804fc7aacc0d264614ced2ac97" alt=""
9.创建swagger配置类,与启动类同级
data:image/s3,"s3://crabby-images/5e05f/5e05fc620462ddc59a72381fdf8ca2f62757f1f4" alt=""
10.在controller层添加swagger配置说明
data:image/s3,"s3://crabby-images/4e5f0/4e5f037ef43a1965d4f017353b3f090a8acce09e" alt=""
至此结束,打开swagger-ui查看效果
data:image/s3,"s3://crabby-images/5777d/5777df86f64edd918743bc6f9f1be2cb71069d57" alt=""
常用注解
在上面的代码中,使用了 @Api.@ApiOperation,下面介绍一下常用的注解
注解 描述 解释
@ApiMarks a class as a Swagger resource. 用于类对象,只有在类对象上标注该注解后,相应的api信息才能展示出来.
@ApiOperation Describes an operation or typically a HTTP method against a specific path. 描述具体的方法
@ApiImplicitParam Represents a single parameter in an API Operation. 描述具体的请求参数,比如具体的响应方法的参数为 HttpServletRequest时,我会从该参数中取一些请求参数,则可以通过该方法单独定义参数.见下面的具体说明,该参数不能单独使用,必须和@ApiImplicitParams一起使用,可参考后面的例子
@ApiImplicitParams A wrapper to allow a list of multiple ApiImplicitParam objects. 组合一组@ApiImplicitParam
@ApiParam Adds additional meta-data for operation parameters. 定义具体的请求参数,类似@RequestParam 参数,直接在方法参数上使用.
@ApiResponse Describes a possible response of an operation.返回值,该类主要有code值与message两个属性,code值必须是http 返回code值,默认会有200,404等,不能单独使用,必须和@ApiResponses一起使用
@ApiResponses A wrapper to allow a list of multiple ApiResponse objects. 组合@ApiResponse
@ApiModel Provides additional information about Swagger models. 提供对请求参数与返回结果中的model的定义
网友评论