当前位置: 首页 > news >正文

朝阳网站开发联系电话百度一直不收录网站

朝阳网站开发联系电话,百度一直不收录网站,专业国外网站建设,网站建好了seo怎么做一、Swagger2介绍 前后端分离开发模式中,api文档是最好的沟通方式。 Swagger 是一个规范和完整的框架,用于生成、描述、调用和可视化 RESTful 风格的 Web 服务。 及时性 (接口变更后,能够及时准确地通知相关前后端开发人员)规范性 (并且保…

一、Swagger2介绍

前后端分离开发模式中,api文档是最好的沟通方式。

Swagger 是一个规范和完整的框架,用于生成、描述、调用和可视化 RESTful 风格的 Web 服务。

  1. 及时性 (接口变更后,能够及时准确地通知相关前后端开发人员)
  2. 规范性 (并且保证接口的规范性,如接口的地址,请求方式,参数及响应格式和错误信息)
  3. 一致性 (接口信息一致,不会出现因开发人员拿到的文档版本不一致,而出现分歧)
  4. 可测性 (直接在接口文档上进行测试,以方便理解业务)

二、配置Swagger2

1、为swagger创建模块结构,到时候其他模块想要调用直接引入该模块就行

1.1 创建common模块

guli-parent下创建模块common

1.2、在common下面创建子模块service-base

2、导入依赖和配置类

2.1、在common的pom.xml引入依赖

    <dependencies><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-web</artifactId><scope>provided</scope></dependency><!--mybatis-plus--><dependency><groupId>com.baomidou</groupId><artifactId>mybatis-plus-boot-starter</artifactId><scope>provided</scope></dependency><!--lombok用来简化实体类:需要安装lombok插件--><dependency><groupId>org.projectlombok</groupId><artifactId>lombok</artifactId><scope>provided</scope></dependency><!--swagger--><dependency><groupId>io.springfox</groupId><artifactId>springfox-swagger2</artifactId><scope>provided</scope></dependency><dependency><groupId>io.springfox</groupId><artifactId>springfox-swagger-ui</artifactId><scope>provided</scope></dependency><!-- redis --><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-data-redis</artifactId></dependency><!-- spring2.X集成redis所需common-pool2<dependency><groupId>org.apache.commons</groupId><artifactId>commons-pool2</artifactId><version>2.6.0</version></dependency>--></dependencies>

2.2、在模块service-base中,创建swagger的配置类

创建包com.atguigu.servicebase.config,创建类SwaggerConfig,基本不用怎么改。其中创建了一个bean,就是Docket对象,用于swagger的正常使用。

package com.atguigu.servicebase.config;import com.google.common.base.Predicates;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import springfox.documentation.builders.ApiInfoBuilder;
import springfox.documentation.builders.PathSelectors;
import springfox.documentation.service.ApiInfo;
import springfox.documentation.service.Contact;
import springfox.documentation.spi.DocumentationType;
import springfox.documentation.spring.web.plugins.Docket;
import springfox.documentation.swagger2.annotations.EnableSwagger2;@Configuration
@EnableSwagger2
public class SwaggerConfig {@Beanpublic Docket webApiConfig() {return new Docket(DocumentationType.SWAGGER_2).groupName("webApi").apiInfo(webApiInfo()).select().paths(Predicates.not(PathSelectors.regex("/admin/.*"))).paths(Predicates.not(PathSelectors.regex("/error.*"))).build();}private ApiInfo webApiInfo() {return new ApiInfoBuilder().title("网站-课程中心API文档").description("本文档描述了课程中心微服务接口定义").version("1.0").contact(new Contact("Helen", "http://atguigu.com","55317332@qq.com")).build();}
}

3、其他项目使用该包

开启组件扫描

要使用swagger直接引用service-base模块即可,但由于swagger里面有spring的组件注解,比如我们有模块,要引入swagger,它里面的启动类EduApplication启动后只会扫描标红的这六个文件下的代码,因此我们要能扫描到service-base模块

@ComponentScan参考博客

https://blog.csdn.net/zxyOVO/article/details/130720065?csdn_share_tail=%7B%22type%22%3A%22blog%22%2C%22rType%22%3A%22article%22%2C%22rId%22%3A%22130720065%22%2C%22source%22%3A%22zxyOVO%22%7D

 因此要添加注解扫描到启动类上

@ComponentScan(basePackages = "com.atguigu")

将com.atguigu组下的包全部进行注解扫描,由于swagger.class在com.atguigu.service_base下,因此swagger的spring注解也能扫描到了。

开始使用

在要引入该模块的地方添加引用依赖,写在pom文件中

        <dependency><groupId>com.atguigu</groupId><artifactId>service_base</artifactId><version>0.0.1-SNAPSHOT</version></dependency>

访问如下链接即可测试了api了

http://localhost:8001/swagger-ui.html

可选内容:定义接口说明和参数说明

定义在类上:@Api

定义在方法上:@ApiOperation

定义在参数上:@ApiParam

@Api(description="讲师管理")
@RestController
@RequestMapping("/admin/edu/teacher")
public class TeacherAdminController {@Autowiredprivate TeacherService teacherService;@ApiOperation(value = "所有讲师列表")@GetMappingpublic List<Teacher> list(){return teacherService.list(null);}@ApiOperation(value = "根据ID删除讲师")@DeleteMapping("{id}")public boolean removeById(@ApiParam(name = "id", value = "讲师ID", required = true)@PathVariable String id){return teacherService.removeById(id);}
}

定义在实体类的属性上:ApiModelProperty

定义在实体类上ApiModel

也就是实体类的都加model

@ApiModel(value = "Teacher查询对象", description = "讲师查询对象封装")
@Data
public class TeacherQuery implements Serializable {private static final long serialVersionUID = 1L;@ApiModelProperty(value = "教师名称,模糊查询")private String name;@ApiModelProperty(value = "头衔 1高级讲师 2首席讲师")private Integer level;@ApiModelProperty(value = "查询开始时间", example = "2019-01-01 10:10:10")private String begin;//注意,这里使用的是String类型,前端传过来的数据无需进行类
型转换@ApiModelProperty(value = "查询结束时间", example = "2019-12-01 10:10:10")private String end;
}

http://www.khdw.cn/news/59157.html

相关文章:

  • php网站有点企业建站流程
  • 做网站上传图片一直错误百度云搜索入口
  • 兰州网站关键字优化高质量内容的重要性
  • 网站开发微信支付详细教程销售课程视频免费
  • 贵州建设厅考试网站安全员seo如何优化图片
  • 一个网站开发流程怎么做网站宣传
  • 临沂网站制作建设合肥网站推广公司排名
  • 网站建设在学校中的作用全国十大跨境电商公司排名
  • 在线logo设计网站百度指数专业版app
  • 米拓 wordpress网站优化排名金苹果系统
  • 哪个网站可以做puzzle海外推广服务
  • ios应用开发语言北京建站优化
  • 网站开发模式有哪些设计师必备的6个网站
  • 企业网站开发介绍推广平台
  • 广州市官网网站建设多少钱推广途径有哪些
  • 技术博客主题wordpressseo工作是什么意思
  • 二七区做网站河南seo外包
  • 厦门网站优化公司武汉关键词seo
  • 腾讯云wordpress 主机信息流优化师是什么
  • 网站开发进度计划优化的意思
  • 织梦怎么做门户网站编程培训机构
  • 做设计有哪些地图网站百度下载2022新版安装
  • 马鞍山制作网站人工智能培训师
  • 做进口产品的网站房产网站建设
  • 怎么网上宣传自己的产品优秀网站seo报价
  • 闵行专业做网站百度seo公司兴田德润
  • 网站制作 北京手机搭建网站
  • 可以用足球做的游戏视频网站百度商店
  • 做spa的网站怎么推广一键优化清理加速
  • 做网站版权所有怎么写品牌词优化