第一个问题:
接口:
/**
* 查询客户详细信息
* BY Oliver_Deng
* @param userId 用户id
* @return
*/
@ApiOperation(value="查询客户详细信息",notes = "根据传入id查询客户详细信息")
@ApiResponses({@ApiResponse(code=400,message="请求参数没填好")})
@ApiImplicitParam(paramType = "query", name = "userId", dataType = "Integer", required = true, value = "客户id")
@GetMapping("/findCustomerDetailByUserId/{userId}")
public Result<Map<String,Object>> findCustomerByUserId(@PathVariable Integer userId){
//客户信息
// CustomerListVo customerMessage = customerUserService.findCustomerByUserID(userId);
//客户车辆信息
// List<CustomerUserCar> cars = customerUserCarService.findCarByUserId(Integer.valueOf(userId)); //not finish yet
//TODO 计次卡、储值卡
return null;
}
Swagger访问:
解决办法:
将paramType 设置为path即可。
paramType:表示参数放在哪个地方
header-->请求参数的获取:@RequestHeader(代码中接收注解)
query-->请求参数的获取:@RequestParam(代码中接收注解)
path(用于restful接口)-->请求参数的获取:@PathVariable(代码中接收注解)
body-->请求参数的获取:@RequestBody(代码中接收注解)
form(不常用)
第二个问题:
接口:
/**
* 查询车辆品牌、车系、年款、车型信息
* BY Oliver_Deng
* @param brandId 车辆品牌ID
* @param familyId 车系ID
* @param groupId 车辆年款ID
* @return
*/
@ApiOperation(value="查询车辆品牌、车系、年款、车型信息",notes = "查询车辆品牌、车系、年款、车型信息,传入子id时先将上级id清空,一次访问只能传入一种id或者不传id")
@ApiImplicitParams({
@ApiImplicitParam(paramType = "query", name = "brandId", dataType = "String", required = false, value = "车辆品牌ID"),
@ApiImplicitParam(paramType = "query", name = "familyId", dataType = "String", required = false, value = "车系ID"),
@ApiImplicitParam(paramType = "query", name = "groupId", dataType = "String", required = false, value = "车辆年款ID")
})
@ApiResponses({@ApiResponse(code=400,message="请求参数没填好")})
@GetMapping("/findCarBrandMessage/{brandId}/{familyId}/{groupId}")
public Result findCarBrandMessage(@PathVariable String brandId,@PathVariable String familyId,@PathVariable String groupId){
return customerUserCarService.findCarBrandMessage(brandId,familyId,groupId);
}
Swageer访问:
查询成功,但是没有数据,我们来DeBug看一下:
可以看到值竟然时这些,并不是为null,所以自然满足了if条件,但功能并不是要如此。
解决办法:
把@ApiImplicitParam参数去掉,用@RequestParam()。
为什么能用@RequestParam()?
RequestParam就是在url后面拼接的参数。
成功: