package ${package}.controller; import com.zt.common.annotation.LogOperation; import com.zt.common.constant.Constant; import com.zt.common.annotation.QueryParam; import com.zt.common.db.query.QueryFilter; import com.zt.common.servlet.Result; import com.zt.common.servlet.PageResult; import com.zt.common.validator.AssertUtils; import com.zt.common.validator.ValidatorUtils; import com.zt.common.validator.group.AddGroup; import com.zt.common.validator.group.DefaultGroup; import com.zt.common.validator.group.UpdateGroup; #if($isExport == 'true') import com.zt.common.utils.ExcelUtils; #end import ${package}.model.${className}; #if($isExport == 'true') import ${package}.excel.${className}Excel; #end import ${package}.service.${className}Service; import io.swagger.annotations.Api; import io.swagger.annotations.ApiImplicitParam; import io.swagger.annotations.ApiImplicitParams; import io.swagger.annotations.ApiOperation; 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; /** * ${comments} * * @author ${author} ${email} * @since ${version} ${date} */ @RestController @RequestMapping("/${moduleName}/${className}/") @Api(tags="${comments}") public class ${className}Controller { @Autowired private ${className}Service ${classBean}Service; @GetMapping("page") @ApiOperation("分页") @ApiImplicitParams({ @ApiImplicitParam(name = Constant.Q.PAGE, value = Constant.QV.PAGE, required = true, dataType = Constant.QT.INT), @ApiImplicitParam(name = Constant.Q.LIMIT, value = Constant.QV.LIMIT, required = true, dataType = Constant.QT.INT), @ApiImplicitParam(name = Constant.Q.ORDER_FIELD, value = Constant.QV.ORDER_FIELD, dataType = Constant.QT.STRING), @ApiImplicitParam(name = Constant.Q.ORDER, value = Constant.QV.ORDER, dataType = Constant.QT.STRING), #foreach($column in $selectColumns) @ApiImplicitParam(name = "${column.attrName}", value = "${column.comments}", dataType = Constant.QT.STRING, format = "${column.columnName}^${column.op}")#if($velocityCount != $selectColumns.size()),#end #end }) public PageResult<${className}> page(@ApiIgnore @QueryParam QueryFilter queryFilter){ return PageResult.ok(${classBean}Service.page(queryFilter)); } @GetMapping("{id}") @ApiOperation("信息") public Result<${className}> get(@PathVariable("id") Long id){ ${className} data = ${classBean}Service.get(id); return Result.ok(data); } @PostMapping @ApiOperation("新增") @LogOperation("新增") public Result insert(@RequestBody ${className} ${modelName}){ //效验数据 ValidatorUtils.validateEntity(${modelName}, AddGroup.class, DefaultGroup.class); ${classBean}Service.insert(${modelName}); return Result.ok(); } @PutMapping @ApiOperation("修改") @LogOperation("修改") public Result update(@RequestBody ${className} ${modelName}){ //效验数据 ValidatorUtils.validateEntity(${modelName}, UpdateGroup.class, DefaultGroup.class); ${classBean}Service.update(${modelName}); return Result.ok(); } @DeleteMapping @ApiOperation("删除") @LogOperation("删除") public Result delete(@RequestBody Long[] ids){ //效验数据 AssertUtils.isArrayEmpty(ids, "id"); ${classBean}Service.delete(ids); return Result.ok(); } #if($isExport == 'true') @GetMapping("export") @ApiOperation("导出") @LogOperation("导出") public void export(@ApiIgnore @QueryParam QueryFilter queryFilter, HttpServletResponse response) throws Exception { List<${className}> list = ${classBean}Service.page(queryFilter); ExcelUtils.exportExcelToTarget(response, null, list, ${className}Excel.class); } #end }