Swagger在SSM中的使用方法

swagger是一個RESTFUL風(fēng)格的web接口框架 逮京,主要是為了獲取到接口文檔 ,這次使用一個項目簡單測試一下 概说,看看效果

使用步驟:

1:導(dǎo)入依賴:

<!--    接口文檔的依賴 -->

    <!--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的界面靜態(tài)文件) -->
    <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("衛(wèi)生監(jiān)督管理項目Forest接口文檔")
                .description("衛(wèi)生監(jiān)督管理項目Forest接口測試")
                .version("1.0.0")
                .termsOfServiceUrl("")
                .license("衛(wèi)生監(jiān)督管理1.0")
                .licenseUrl("http://127.0.0.1:8888/")
                .build();
    }
}

4:在實體類中的注解配置

@ApiModel(description = "用戶數(shù)據(jù)")
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;

/**
 * 異步交互技術(shù)
 * @RestController = @Controller + @ResponseBody
 *
 * 在異步交互技術(shù)的處理器中震缭,所有的返回值為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.根據(jù)用戶username查詢到單條記錄
     * 2.判斷用戶對象是為null
     * 3.如果為空表示用戶名不匹配:給用戶提示(響應(yīng)用戶名有誤的提示)
     * 4.如果不為空表示用戶名匹配:
     * 5.判斷密碼是否匹配:用戶提交的密碼與查詢到密碼進(jìn)行比對
     * 6.比對成功表示用戶登錄成功:將用戶信息存放在session中
     * 7.比對不成功表示用戶提供的密碼有誤:給用戶提示(響應(yīng)密碼有誤的提示)
     */
    @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 查看本次項目的接口文檔

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末战虏,一起剝皮案震驚了整個濱河市拣宰,隨后出現(xiàn)的幾起案子党涕,更是在濱河造成了極大的恐慌,老刑警劉巖巡社,帶你破解...
    沈念sama閱讀 217,509評論 6 504
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件膛堤,死亡現(xiàn)場離奇詭異,居然都是意外死亡晌该,警方通過查閱死者的電腦和手機肥荔,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,806評論 3 394
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來气笙,“玉大人次企,你說我怎么就攤上這事∏逼裕” “怎么了?”我有些...
    開封第一講書人閱讀 163,875評論 0 354
  • 文/不壞的土叔 我叫張陵舟茶,是天一觀的道長谭期。 經(jīng)常有香客問我,道長吧凉,這世上最難降的妖魔是什么隧出? 我笑而不...
    開封第一講書人閱讀 58,441評論 1 293
  • 正文 為了忘掉前任,我火速辦了婚禮阀捅,結(jié)果婚禮上胀瞪,老公的妹妹穿的比我還像新娘。我一直安慰自己饲鄙,他們只是感情好凄诞,可當(dāng)我...
    茶點故事閱讀 67,488評論 6 392
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著忍级,像睡著了一般帆谍。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上轴咱,一...
    開封第一講書人閱讀 51,365評論 1 302
  • 那天汛蝙,我揣著相機與錄音,去河邊找鬼朴肺。 笑死窖剑,一個胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的戈稿。 我是一名探鬼主播西土,決...
    沈念sama閱讀 40,190評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼器瘪!你這毒婦竟也來了翠储?” 一聲冷哼從身側(cè)響起绘雁,我...
    開封第一講書人閱讀 39,062評論 0 276
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎援所,沒想到半個月后庐舟,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,500評論 1 314
  • 正文 獨居荒郊野嶺守林人離奇死亡住拭,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,706評論 3 335
  • 正文 我和宋清朗相戀三年挪略,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片滔岳。...
    茶點故事閱讀 39,834評論 1 347
  • 序言:一個原本活蹦亂跳的男人離奇死亡杠娱,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出谱煤,到底是詐尸還是另有隱情摊求,我是刑警寧澤,帶...
    沈念sama閱讀 35,559評論 5 345
  • 正文 年R本政府宣布刘离,位于F島的核電站室叉,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏硫惕。R本人自食惡果不足惜茧痕,卻給世界環(huán)境...
    茶點故事閱讀 41,167評論 3 328
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望恼除。 院中可真熱鬧踪旷,春花似錦、人聲如沸豁辉。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,779評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽秋忙。三九已至彩掐,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間灰追,已是汗流浹背堵幽。 一陣腳步聲響...
    開封第一講書人閱讀 32,912評論 1 269
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留弹澎,地道東北人朴下。 一個月前我還...
    沈念sama閱讀 47,958評論 2 370
  • 正文 我出身青樓,卻偏偏與公主長得像苦蒿,于是被迫代替她去往敵國和親殴胧。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 44,779評論 2 354

推薦閱讀更多精彩內(nèi)容