package ${package}.modules.${moduleName}.controller<#if subModuleName??>.${subModuleName}; import ${package}.common.annotation.LogOperation; import ${package}.common.constant.Constant; import ${package}.common.page.PageData; import ${package}.common.utils.ExcelUtils; import ${package}.common.utils.Result; import ${package}.common.validator.AssertUtils; import ${package}.common.validator.ValidatorUtils; import ${package}.common.validator.group.AddGroup; import ${package}.common.validator.group.DefaultGroup; import ${package}.common.validator.group.UpdateGroup; import ${package}.modules.${moduleName}.dto<#if subModuleName??>.${subModuleName}.${ClassName}DTO; import ${package}.modules.${moduleName}.excel<#if subModuleName??>.${subModuleName}.${ClassName}Excel; import ${package}.modules.${moduleName}.service<#if subModuleName??>.${subModuleName}.${ClassName}Service; import io.swagger.annotations.Api; import io.swagger.annotations.ApiImplicitParam; import io.swagger.annotations.ApiImplicitParams; import io.swagger.annotations.ApiOperation; import org.apache.shiro.authz.annotation.RequiresPermissions; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.web.bind.annotation.*; import springfox.documentation.annotations.ApiIgnore; import javax.servlet.http.HttpServletResponse; import java.util.List; import java.util.Map; /** * ${tableComment} * * @author ${author} ${email} * @since ${version} ${date} */ @RestController @RequestMapping("${moduleName}/${classname}") @Api(tags="${tableComment}") public class ${ClassName}Controller { @Autowired private ${ClassName}Service ${className}Service; @GetMapping("page") @ApiOperation("分页") @ApiImplicitParams({ @ApiImplicitParam(name = Constant.PAGE, value = "当前页码,从1开始", paramType = "query", required = true, dataType="int") , @ApiImplicitParam(name = Constant.LIMIT, value = "每页显示记录数", paramType = "query",required = true, dataType="int") , @ApiImplicitParam(name = Constant.ORDER_FIELD, value = "排序字段", paramType = "query", dataType="String") , @ApiImplicitParam(name = Constant.ORDER, value = "排序方式,可选值(asc、desc)", paramType = "query", dataType="String") }) @RequiresPermissions("${moduleName}:${classname}:page") public Result> page(@ApiIgnore @RequestParam Map params){ PageData<${ClassName}DTO> page = ${className}Service.page(params); return new Result>().ok(page); } @GetMapping("{id}") @ApiOperation("信息") @RequiresPermissions("${moduleName}:${classname}:info") public Result<${ClassName}DTO> get(@PathVariable("id") Long id){ ${ClassName}DTO data = ${className}Service.get(id); return new Result<${ClassName}DTO>().ok(data); } @PostMapping @ApiOperation("保存") @LogOperation("保存") @RequiresPermissions("${moduleName}:${classname}:save") public Result save(@RequestBody ${ClassName}DTO dto){ //效验数据 ValidatorUtils.validateEntity(dto, AddGroup.class, DefaultGroup.class); ${className}Service.save(dto); return new Result(); } @PutMapping @ApiOperation("修改") @LogOperation("修改") @RequiresPermissions("${moduleName}:${classname}:update") public Result update(@RequestBody ${ClassName}DTO dto){ //效验数据 ValidatorUtils.validateEntity(dto, UpdateGroup.class, DefaultGroup.class); ${className}Service.update(dto); return new Result(); } @DeleteMapping @ApiOperation("删除") @LogOperation("删除") @RequiresPermissions("${moduleName}:${classname}:delete") public Result delete(@RequestBody Long[] ids){ //效验数据 AssertUtils.isArrayEmpty(ids, "id"); ${className}Service.delete(ids); return new Result(); } @GetMapping("export") @ApiOperation("导出") @LogOperation("导出") @RequiresPermissions("${moduleName}:${classname}:export") public void export(@ApiIgnore @RequestParam Map params, HttpServletResponse response) throws Exception { List<${ClassName}DTO> list = ${className}Service.list(params); ExcelUtils.exportExcelToTarget(response, null, "${tableComment}", list, ${ClassName}Excel.class); } }