| 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 | 
| } |