bkjxxxw/build/classes/templates/modules/gen/curd/controller.xml

265 lines
10 KiB
XML

<?xml version="1.0" encoding="utf-8"?>
<template>
<name>controller</name>
<filePath>src/main/java/${packageName}/${moduleName}/web/${subModuleName}</filePath>
<fileName>${ClassName}Controller.java</fileName>
<content><![CDATA[
/**
* Copyright ® 长春千鸟科技
* 版权所有。
* http://www.ccqnsoft.com
*/
package ${packageName}.${moduleName}.web<#if subModuleName != "">.${subModuleName}</#if>;
import java.util.List;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import javax.validation.ConstraintViolationException;
import org.apache.shiro.authz.annotation.Logical;
import org.apache.shiro.authz.annotation.RequiresPermissions;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Controller;
import org.springframework.ui.Model;
import org.springframework.web.bind.annotation.ModelAttribute;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestMethod;
import org.springframework.web.bind.annotation.RequestParam;
import org.springframework.web.multipart.MultipartFile;
import org.springframework.web.servlet.mvc.support.RedirectAttributes;
<#list table.importGridJavaList as i>
import ${i};
</#list>
import com.google.common.collect.Lists;
import com.jeeplus.common.utils.DateUtils;
import com.jeeplus.common.utils.MyBeanUtils;
import com.jeeplus.common.config.Global;
import com.jeeplus.common.persistence.Page;
import com.jeeplus.common.web.BaseController;
import com.jeeplus.common.utils.StringUtils;
import com.jeeplus.common.utils.excel.ExportExcel;
import com.jeeplus.common.utils.excel.ImportExcel;
import ${packageName}.${moduleName}.entity<#if subModuleName != "">.${subModuleName}</#if>.${ClassName};
import ${packageName}.${moduleName}.service<#if subModuleName != "">.${subModuleName}</#if>.${ClassName}Service;
/**
* <p>Class :${functionName}Controller
* <p>功能描述: 功能描述
*
* @author ${functionAuthor}
* @version 1.0.0
*<p>
*-----------------------------------------------------<br>
* 创建时间:${functionVersion}
*-----------------------------------------------------<br>
*</p>
*/
@Controller
@RequestMapping(value = "${r"${adminPath}"}/${urlPrefix}")
public class ${ClassName}Controller extends BaseController {
@Autowired
private ${ClassName}Service ${className}Service;
@ModelAttribute
public ${ClassName} get(@RequestParam(required=false) String id) {
${ClassName} entity = null;
if (StringUtils.isNotBlank(id)){
entity = ${className}Service.get(id);
}
if (entity == null){
entity = new ${ClassName}();
}
return entity;
}
/**
* <p>Description:${functionNameSimple}列表页面
* @return String 列表路径
* @param 类型 参数中文释义(多个参数用<br>分隔)
*<p>
*/
@RequiresPermissions("${permissionPrefix}:list")
@RequestMapping(value = {"list", ""})
public String list(${ClassName} ${className}, HttpServletRequest request, HttpServletResponse response, Model model) {
Page<${ClassName}> page = ${className}Service.findPage(new Page<${ClassName}>(request, response), ${className});
model.addAttribute("page", page);
return "ccqnsoft/${lastPackageName}/${viewPrefix}List";
}
/**
* <p>Description:查看,增加,编辑${functionNameSimple}表单页面
* @return String 返回路径
* @param 类型 参数中文释义(多个参数用<br>分隔)
* @author
*<p>
*/
@RequiresPermissions(value={"${permissionPrefix}:view","${permissionPrefix}:add","${permissionPrefix}:edit"},logical=Logical.OR)
@RequestMapping(value = "form")
public String form(${ClassName} ${className}, Model model) {
model.addAttribute("${className}", ${className});
return "ccqnsoft/${lastPackageName}/${viewPrefix}Form";
}
/**
* <p>Description:保存${functionNameSimple}
* @return String 返回路径
* @param 类型 参数中文释义(多个参数用<br>分隔)
*<p>
*/
@RequiresPermissions(value={"${permissionPrefix}:add","${permissionPrefix}:edit"},logical=Logical.OR)
@RequestMapping(value = "save")
public String save(${ClassName} ${className}, Model model, RedirectAttributes redirectAttributes) throws Exception{
if (!beanValidator(model, ${className})){
return form(${className}, model);
}
if(!${className}.getIsNewRecord()){//编辑表单保存
${ClassName} t = ${className}Service.get(${className}.getId());//从数据库取出记录的值
MyBeanUtils.copyBeanNotNull2Bean(${className}, t);//将编辑表单中的非NULL值覆盖数据库记录中的值
${className}Service.save(t);//保存
}else{//新增表单保存
${className}Service.save(${className});//保存
}
addMessage(redirectAttributes, "保存${functionNameSimple}成功");
return "redirect:"+Global.getAdminPath()+"/${viewPrefix}/?repage";
}
/**
* <p>Description:删除${functionNameSimple}
* @return String 返回路径
* @param 类型 参数中文释义(多个参数用<br>分隔)
*<p>
*/
@RequiresPermissions("${permissionPrefix}:del")
@RequestMapping(value = "delete")
public String delete(${ClassName} ${className}, RedirectAttributes redirectAttributes) {
${className}Service.delete(${className});
addMessage(redirectAttributes, "删除${functionNameSimple}成功");
return "redirect:"+Global.getAdminPath()+"/${viewPrefix}/?repage";
}
/**
* <p>Description:批量删除${functionNameSimple}
* @return String 返回路径
* @param 类型 参数中文释义(多个参数用<br>分隔)
*<p>
*/
@RequiresPermissions("${permissionPrefix}:del")
@RequestMapping(value = "deleteAll")
public String deleteAll(String ids, RedirectAttributes redirectAttributes) {
String idArray[] =ids.split(",");
for(String id : idArray){
${className}Service.delete(${className}Service.get(id));
}
addMessage(redirectAttributes, "删除${functionNameSimple}成功");
return "redirect:"+Global.getAdminPath()+"/${viewPrefix}/?repage";
}
/**
* <p>Description:导出excel文件
* @return String 返回路径
* @param 类型 参数中文释义(多个参数用<br>分隔)
*<p>
*/
@RequiresPermissions("${permissionPrefix}:export")
@RequestMapping(value = "export", method=RequestMethod.POST)
public String exportFile(${ClassName} ${className}, HttpServletRequest request, HttpServletResponse response, RedirectAttributes redirectAttributes) {
try {
String fileName = "${functionNameSimple}"+DateUtils.getDate("yyyyMMddHHmmss")+".xlsx";
Page<${ClassName}> page = ${className}Service.findPage(new Page<${ClassName}>(request, response, -1), ${className});
new ExportExcel("${functionNameSimple}", ${ClassName}.class).setDataList(page.getList()).write(response, fileName).dispose();
return null;
} catch (Exception e) {
addMessage(redirectAttributes, "导出${functionNameSimple}记录失败!失败信息:"+e.getMessage());
}
return "redirect:"+Global.getAdminPath()+"/${viewPrefix}/?repage";
}
/**
* <p>Description:导入Excel数据
* @return String 返回路径
* @param 类型 参数中文释义(多个参数用<br>分隔)
*<p>
*/
@RequiresPermissions("${permissionPrefix}:import")
@RequestMapping(value = "import", method=RequestMethod.POST)
public String importFile(MultipartFile file, RedirectAttributes redirectAttributes) {
try {
int successNum = 0;
int failureNum = 0;
StringBuilder failureMsg = new StringBuilder();
ImportExcel ei = new ImportExcel(file, 1, 0);
List<${ClassName}> list = ei.getDataList(${ClassName}.class);
for (${ClassName} ${className} : list){
try{
${className}Service.save(${className});
successNum++;
}catch(ConstraintViolationException ex){
failureNum++;
}catch (Exception ex) {
failureNum++;
}
}
if (failureNum>0){
failureMsg.insert(0, ",失败 "+failureNum+" 条${functionNameSimple}记录。");
}
addMessage(redirectAttributes, "已成功导入 "+successNum+" 条${functionNameSimple}记录"+failureMsg);
} catch (Exception e) {
addMessage(redirectAttributes, "导入${functionNameSimple}失败!失败信息:"+e.getMessage());
}
return "redirect:"+Global.getAdminPath()+"/${viewPrefix}/?repage";
}
/**
* <p>Description:下载导入${functionNameSimple}数据模板
* @return String 返回路径
* @param 类型 参数中文释义(多个参数用<br>分隔)
*<p>
*/
@RequiresPermissions("${permissionPrefix}:import")
@RequestMapping(value = "import/template")
public String importFileTemplate(HttpServletResponse response, RedirectAttributes redirectAttributes) {
try {
String fileName = "${functionNameSimple}数据导入模板.xlsx";
List<${ClassName}> list = Lists.newArrayList();
new ExportExcel("${functionNameSimple}数据", ${ClassName}.class, 1).setDataList(list).write(response, fileName).dispose();
return null;
} catch (Exception e) {
addMessage(redirectAttributes, "导入模板下载失败!失败信息:"+e.getMessage());
}
return "redirect:"+Global.getAdminPath()+"/${viewPrefix}/?repage";
}
<#list table.columnList as c>
<#-- 如果存在自定义java对象 -->
<#if c.tableName?? && c.tableName!="">
/**
* <p>Description:选择${c.comments}
* @param 类型 参数中文释义(多个参数用<br>分隔)
*<p>
*/
@RequestMapping(value = "select${c.simpleJavaField}")
public String select${c.simpleJavaField}(${c.simpleJavaType} ${c.simpleJavaField}, String url, String fieldLabels, String fieldKeys, String searchLabel, String searchKey, HttpServletRequest request, HttpServletResponse response, Model model) {
Page<${c.simpleJavaType}> page = ${className}Service.findPageBy${c.simpleJavaField}(new Page<${c.simpleJavaType}>(request, response), ${c.simpleJavaField});
model.addAttribute("labelNames", fieldLabels.split("\\|"));
model.addAttribute("labelValues", fieldKeys.split("\\|"));
model.addAttribute("fieldLabels", fieldLabels);
model.addAttribute("fieldKeys", fieldKeys);
model.addAttribute("url", url);
model.addAttribute("searchLabel", searchLabel);
model.addAttribute("searchKey", searchKey);
model.addAttribute("obj", ${c.simpleJavaField});
model.addAttribute("page", page);
return "modules/sys/gridselect";
}
</#if>
</#list>
}]]>
</content>
</template>