Swagger在SSM中的使用方法

swagger是一个RESTFUL风格的web接口框架 ,主要是为了获取到接口文档 ,这次使用一个项目简单测试一下 ,看看效果

使用步骤:

1:导入依赖:

<!--    接口文档的依赖 -->

    <!--springfox的核心jar包 -->
    <dependency>
      <groupId>io.springfox</groupId>
      <artifactId>springfox-swagger2</artifactId>
      <version>2.9.2</version>
      <exclusions>
        <exclusion>
          <artifactId>slf4j-api</artifactId>
          <groupId>org.slf4j</groupId>
        </exclusion>
        <exclusion>
          <artifactId>jackson-annotations</artifactId>
          <groupId>com.fasterxml.jackson.core</groupId>
        </exclusion>
        <exclusion>
          <artifactId>spring-aop</artifactId>
          <groupId>org.springframework</groupId>
        </exclusion>
        <exclusion>
          <artifactId>spring-context</artifactId>
          <groupId>org.springframework</groupId>
        </exclusion>
        <exclusion>
          <artifactId>spring-beans</artifactId>
          <groupId>org.springframework</groupId>
        </exclusion>
      </exclusions>
    </dependency>
    <!--springfox-ui的jar包(里面包含了swagger的界面静态文件) -->
    <dependency>
      <groupId>io.springfox</groupId>
      <artifactId>springfox-swagger-ui</artifactId>
      <version>2.9.2</version>
    </dependency>

2: springmvc配置文件中配置swagger的放行地址

<!--配置下 swagger 的地址放行-->
    <mvc:resources location="classpath:/META-INF/resources/" mapping="/swagger-ui.html"/>
    <mvc:resources location="classpath:/META-INF/resources/webjars/" mapping="/webjars/**"/>

3:添加swagger的配置类(虽然是配置类 ,最好直接写到controller层中 )

package com.newcapec.org.controller;


import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.web.servlet.config.annotation.EnableWebMvc;
import springfox.documentation.builders.ApiInfoBuilder;
import springfox.documentation.builders.RequestHandlerSelectors;
import springfox.documentation.service.ApiInfo;
import springfox.documentation.spi.DocumentationType;
import springfox.documentation.spring.web.plugins.Docket;
import springfox.documentation.swagger2.annotations.EnableSwagger2;

@EnableSwagger2 //开启 swagger2
@EnableWebMvc//声明是 web 项目
@Configuration
public class SwaggerConfig {
    @Bean
    public Docket api(ApiInfo apiInfo) {
        return new Docket(DocumentationType.SWAGGER_2)
                .select()
//                .apis(RequestHandlerSelectors.any())
                .apis(RequestHandlerSelectors.basePackage("com.newcapec.org.controller"))
                .build()
                .apiInfo(apiInfo);
    }
    @Bean
    public ApiInfo apiInfo() {
        return new ApiInfoBuilder()
                .title("卫生监督管理项目Forest接口文档")
                .description("卫生监督管理项目Forest接口测试")
                .version("1.0.0")
                .termsOfServiceUrl("")
                .license("卫生监督管理1.0")
                .licenseUrl("http://127.0.0.1:8888/")
                .build();
    }
}

4:在实体类中的注解配置

@ApiModel(description = "用户数据")
public class Users {
    @ApiModelProperty(value = "用户主键,查询时返回",hidden = true)
    private Integer id;
    @ApiModelProperty(value = "用户名字",required = true,example = "TOM")
    private String username;
    @ApiModelProperty(value = "用户密码",required = true,example = "123")
    private String password;
    @ApiModelProperty(value = "真实名字",required = false,example = "汤姆")
    private String realname;
    private List<Integer> rolesList;

    public Integer getId() {
        return id;
    }

    public void setId(Integer id) {
        this.id = id;
    }

    public String getUsername() {
        return username;
    }

    public void setUsername(String username) {
        this.username = username;
    }

    public String getPassword() {
        return password;
    }

    public void setPassword(String password) {
        this.password = password;
    }

    public String getRealname() {
        return realname;
    }

    public void setRealname(String realname) {
        this.realname = realname;
    }

    public List<Integer> getRolesList() {
        return rolesList;
    }

    public void setRolesList(List<Integer> rolesList) {
        this.rolesList = rolesList;
    }
}

5:在控制器中的注解配置

package com.newcapec.org.controller;

import com.newcapec.org.entity.Users;
import com.newcapec.org.service.UsersService;
import com.newcapec.org.utils.ResponseJson;
import io.swagger.annotations.Api;
import io.swagger.annotations.ApiOperation;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.*;

import javax.servlet.http.HttpSession;
import java.util.Map;

/**
 * 异步交互技术
 * @RestController = @Controller + @ResponseBody
 *
 * 在异步交互技术的处理器中,所有的返回值为ResponseJson对象
 */
@RestController
@RequestMapping("/users")
@Api(tags = "用户管理模块" )
public class UsersController {

    @Autowired
    private UsersService usersService;

    @PostMapping("/add")
    @ApiOperation("添加用户")
    public ResponseJson add(@RequestBody Users entity){
        usersService.add(entity);
        return ResponseJson.success();
    }

    @PutMapping("/edit")
    @ApiOperation("修改用户")
    public ResponseJson edit(@RequestBody Users entity){
        usersService.edit(entity);
        return ResponseJson.success();
    }

    @DeleteMapping("/remove/{id}")
    @ApiOperation("删除用户")
    public ResponseJson remove(@PathVariable Integer id){
        usersService.remove(id);
        return ResponseJson.success();
    }

    @DeleteMapping("/remove")
    @ApiOperation("批量删除用户")
    public ResponseJson removeBatch(Integer[] id){
        usersService.removeBatch(id);
        return ResponseJson.success();
    }

    @GetMapping("/find/{id}")
    @ApiOperation("通过id查询用户")
    public ResponseJson findById(@PathVariable Integer id){
        Users users = usersService.findById(id);
        return ResponseJson.success(users);
    }

    @GetMapping("/find")
    @ApiOperation("分页查询用户")
    public ResponseJson find(@RequestParam(value = "pageNum", defaultValue = "1") Integer pageNum,
                             @RequestParam(value = "pageSize", defaultValue = "10") Integer pageSize,
                             Users entity){
        Map<String,Object> map = usersService.find(pageNum, pageSize, entity);
        return ResponseJson.success(map);
    }

    @GetMapping("/findAll")
    @ApiOperation("查询所有用户")
    public ResponseJson findAll(){
        return ResponseJson.success(usersService.findAll());
    }

    /**
     * 登录
     * 1.根据用户username查询到单条记录
     * 2.判断用户对象是为null
     * 3.如果为空表示用户名不匹配:给用户提示(响应用户名有误的提示)
     * 4.如果不为空表示用户名匹配:
     * 5.判断密码是否匹配:用户提交的密码与查询到密码进行比对
     * 6.比对成功表示用户登录成功:将用户信息存放在session中
     * 7.比对不成功表示用户提供的密码有误:给用户提示(响应密码有误的提示)
     */
    @PostMapping("/login")
    @ApiOperation("用户登陆")
    public ResponseJson login(String username, String password, HttpSession session){
        Users users = usersService.findByUsername(username);
        if(users == null){
            return ResponseJson.error(501, "用户名有误");
        }
        if(users.getPassword().equals(password)){
            session.setAttribute("loginUser", users);
            return ResponseJson.success();
        }
        return ResponseJson.error(501, "密码有误");
    }

    @GetMapping("/logout")
    @ApiOperation("用户登出")
    public ResponseJson logout(HttpSession session){
        session.removeAttribute("loginUser");
        session.invalidate();
        return ResponseJson.success();
    }

    @GetMapping("/exists")
    @ApiOperation("用户是否存在")
    public Map<String, Object> exists(String username){
        return usersService.exists(username);
    }
}

启动项目 ,直接访问 http://localhost:8888/swagger-ui.html 查看本次项目的接口文档

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 204,293评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,604评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,958评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,729评论 1 277
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,719评论 5 366
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,630评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,000评论 3 397
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,665评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,909评论 1 299
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,646评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,726评论 1 330
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,400评论 4 321
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,986评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,959评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,197评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 44,996评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,481评论 2 342

推荐阅读更多精彩内容