**需求分析和设计**
接口设计:
-设置营业状态
-管理端查询营业状态
-用户端查询营业状态
redis字符串进行存储,1表示营业0表示打烊
关于两个bean方法名字相同都注入容器会冲突
在RestController后面指定名称来区分
Controller层admin包
@RestController("adminShopController")
@RequestMapping("/admin/shop")
@Api(tags = "店铺的相关接口")
@Slf4j
public class ShopController {
@Autowired
private RedisTemplate redisTemplate;
@PutMapping("/{status}")
@ApiOperation("设置营业状态")
public Result setStatus(@PathVariable Integer status){
log.info("设置店铺的营业状态为{}",status == 1 ? "营业中" : "打烊中");
redisTemplate.opsForValue().set("SHOP_STATUS",status);
return Result.success();
}
@GetMapping("/status")
@ApiOperation("获取店铺的营业状态")
public Result<Integer> getStatus(){
Integer status = (Integer) redisTemplate.opsForValue().get("SHOP_STATUS");
log.info("获取店铺的营业状态为{}",status == 1 ? "营业中":"打烊中");
return Result.success(status);
}
}
Controller层user包下同样需要店铺状态,只是只能查询状态,不能设值
两个包下其他都相同,唯有user包下的方法不能状态设置只能查询,映射redis
设置两个相同的方法docket,改变docket.groupname设定为不同端的接口文档
basepackage用以扫描包
@Bean
public Docket docket1() {
ApiInfo apiInfo = new ApiInfoBuilder()
.title("苍穹外卖项目接口文档")
.version("2.0")
.description("苍穹外卖项目接口文档")
.build();
Docket docket = new Docket(DocumentationType.SWAGGER_2)
.groupName("用户端接口")
.apiInfo(apiInfo)
.select()
.apis(RequestHandlerSelectors.basePackage("com.sky.controller.user"))
.paths(PathSelectors.any())
.build();
return docket;
}