代码生成器工具类GenUtils

原创 2018年04月16日 18:27:35

上代码GenUtils

import BDException;
import DateUtils;
import ColumnDO;
import TableDO;
import org.apache.commons.configuration.Configuration;
import org.apache.commons.configuration.ConfigurationException;
import org.apache.commons.configuration.PropertiesConfiguration;
import org.apache.commons.io.IOUtils;
import org.apache.commons.lang.StringUtils;
import org.apache.commons.lang.WordUtils;
import org.apache.velocity.Template;
import org.apache.velocity.VelocityContext;
import org.apache.velocity.app.Velocity;

import java.io.File;
import java.io.IOException;
import java.io.StringWriter;
import java.util.*;
import java.util.zip.ZipEntry;
import java.util.zip.ZipOutputStream;

/**
 * 代码生成器   工具类
 */
public class GenUtils {

         //获取模板的方法
	public static List<String> getTemplates(){
		List<String> templates = new ArrayList<String>();

		   //把生成代码的配置文件都加载到list集合中
		templates.add("templates/common/generator/domain.java.vm");
		templates.add("templates/common/generator/Dao.java.vm");
		//templates.add("templates/common/generator/Mapper.java.vm");
		templates.add("templates/common/generator/Mapper.xml.vm");
		templates.add("templates/common/generator/Service.java.vm");
		templates.add("templates/common/generator/ServiceImpl.java.vm");
		templates.add("templates/common/generator/Controller.java.vm");
		templates.add("templates/common/generator/list.html.vm");
		templates.add("templates/common/generator/add.html.vm");
		templates.add("templates/common/generator/edit.html.vm");
		templates.add("templates/common/generator/list.js.vm");
		templates.add("templates/common/generator/add.js.vm");
		templates.add("templates/common/generator/edit.js.vm");
		//templates.add("templates/common/generator/menu.sql.vm");
		return templates;
	}
	
	/**
	 * 生成代码
	 */

	public static void generatorCode(Map<String, String> table,
		List<Map<String, String>> columns, ZipOutputStream zip){
		//配置信息
		 Configuration config = getConfig();
		//表信息
		TableDO TableDO = new TableDO();
		TableDO.setTableName(table.get("tableName"));
		TableDO.setComments(table.get("tableComment"));
		//表名转换成Java类名
		String className = tableToJava(TableDO.getTableName(), config.getString("tablePrefix"),config.getString("autoRemovePre"));
		TableDO.setClassName(className);
		TableDO.setClassname(StringUtils.uncapitalize(className));
		
		//列信息
		List<ColumnDO> columsList = new ArrayList<>();
		for(Map<String, String> column : columns){
			ColumnDO ColumnDO = new ColumnDO();
			ColumnDO.setColumnName(column.get("columnName"));
			ColumnDO.setDataType(column.get("dataType"));
			ColumnDO.setComments(column.get("columnComment"));
			ColumnDO.setExtra(column.get("extra"));
			
			//列名转换成Java属性名
			String attrName = columnToJava(ColumnDO.getColumnName());
			ColumnDO.setAttrName(attrName);
			ColumnDO.setAttrname(StringUtils.uncapitalize(attrName));
			
			//列的数据类型,转换成Java类型
			String attrType = config.getString(ColumnDO.getDataType(), "unknowType");
			ColumnDO.setAttrType(attrType);
			
			//是否主键
			if("PRI".equalsIgnoreCase(column.get("columnKey")) && TableDO.getPk() == null){
				TableDO.setPk(ColumnDO);
			}
			
			columsList.add(ColumnDO);
		}
		TableDO.setColumns(columsList);
		
		//没主键,则第一个字段为主键
		if(TableDO.getPk() == null){
			TableDO.setPk(TableDO.getColumns().get(0));
		}
		
		//设置velocity资源加载器
		Properties prop = new Properties();  
		prop.put("file.resource.loader.class", "org.apache.velocity.runtime.resource.loader.ClasspathResourceLoader");  
		Velocity.init(prop);
		
		//封装模板数据
		Map<String, Object> map = new HashMap<>();
		map.put("tableName", TableDO.getTableName());
		map.put("comments", TableDO.getComments());
		map.put("pk", TableDO.getPk());
		map.put("className", TableDO.getClassName());
		map.put("classname", TableDO.getClassname());
		map.put("pathName", config.getString("package").substring(config.getString("package").lastIndexOf(".")+1));
		map.put("columns", TableDO.getColumns());
		map.put("package", config.getString("package"));
		map.put("author", config.getString("author"));
		map.put("email", config.getString("email"));
		map.put("datetime", DateUtils.format(new Date(), DateUtils.DATE_TIME_PATTERN));
        VelocityContext context = new VelocityContext(map);
        
        //获取模板列表
		List<String> templates = getTemplates();
		for(String template : templates){
			//渲染模板
			StringWriter sw = new StringWriter();
			Template tpl = Velocity.getTemplate(template, "UTF-8");
			tpl.merge(context, sw);
			
			try {
				//添加到zip
				zip.putNextEntry(new ZipEntry(getFileName(template, TableDO.getClassname(),TableDO.getClassName(), config.getString("package").substring(config.getString("package").lastIndexOf(".")+1))));  
				IOUtils.write(sw.toString(), zip, "UTF-8");
				IOUtils.closeQuietly(sw);
				zip.closeEntry();
			} catch (IOException e) {
				throw new BDException("渲染模板失败,表名:" + TableDO.getTableName(), e);
			}
		}
	}
	
	
	/**
	 * 列名转换成Java属性名
	 */
	public static String columnToJava(String columnName) {
		return WordUtils.capitalizeFully(columnName, new char[]{'_'}).replace("_", "");
	}
	
	/**
	 * 表名转换成Java类名
	 */
	public static String tableToJava(String tableName, String tablePrefix,String autoRemovePre) {
		if ("true".equals(autoRemovePre)) {
			tableName = tableName.substring(tableName.indexOf("_")+1);
		}
		if(StringUtils.isNotBlank(tablePrefix)){
			tableName = tableName.replace(tablePrefix, "");
		}
		
		return columnToJava(tableName);
	}
	
	/**
	 * 获取配置信息
	 */
	public static Configuration getConfig(){
		try {
			return new PropertiesConfiguration("generator.properties");
		} catch (ConfigurationException e) {
			throw new BDException("获取配置文件失败,", e);
		}
	}
	
	/**
	 * 获取文件名
	 */
	public static String getFileName(String template, String classname,String className, String packageName){
		String packagePath = "main" + File.separator + "java" + File.separator;
		//String modulesname=config.getString("packageName");
		if(StringUtils.isNotBlank(packageName)){
			packagePath += packageName.replace(".", File.separator) + File.separator;
		}
		
		if(template.contains("domain.java.vm")){
			return packagePath + "domain" + File.separator + className + "DO.java";
		}
		
		if(template.contains("Dao.java.vm")){
			return packagePath + "dao" + File.separator + className + "Dao.java";
		}
		
//		if(template.contains("Mapper.java.vm")){
//			return packagePath + "dao" + File.separator + className + "Mapper.java";
//		}

		if(template.contains("Service.java.vm")){
			return packagePath + "service" + File.separator + className + "Service.java";
		}
		
		if(template.contains("ServiceImpl.java.vm")){
			return packagePath + "service" + File.separator + "impl" + File.separator + className + "ServiceImpl.java";
		}
		
		if(template.contains("Controller.java.vm")){
			return packagePath + "controller" + File.separator + className + "Controller.java";
		}

		if(template.contains("Mapper.xml.vm")){
			return "main" + File.separator + "resources" + File.separator + "mybatis" + File.separator + packageName + File.separator + className + "Mapper.xml";
		}

		if(template.contains("list.html.vm")){
			return "main" + File.separator + "resources" + File.separator + "templates" + File.separator
					+ packageName + File.separator + classname + File.separator + classname + ".html";
	//				+ "modules" + File.separator + "generator" + File.separator + className.toLowerCase() + ".html";
		}
		if(template.contains("add.html.vm")){
			return "main" + File.separator + "resources" + File.separator + "templates" + File.separator
					+ packageName + File.separator + classname + File.separator +  "add.html";
		}
		if(template.contains("edit.html.vm")){
			return "main" + File.separator + "resources" + File.separator + "templates" + File.separator
					+ packageName + File.separator + classname + File.separator +  "edit.html";
		}
		
		if(template.contains("list.js.vm")){
			return "main" + File.separator + "resources" + File.separator + "static" + File.separator + "js" + File.separator
					+ "appjs" + File.separator + packageName + File.separator + classname + File.separator + classname+ ".js";
			//		+ "modules" + File.separator + "generator" + File.separator + className.toLowerCase() + ".js";
		}
		if(template.contains("add.js.vm")){
			return "main" + File.separator + "resources" + File.separator + "static" + File.separator + "js" + File.separator
                    + "appjs" + File.separator+ packageName + File.separator + classname + File.separator + "add.js";
		}
		if(template.contains("edit.js.vm")){
			return "main" + File.separator + "resources" + File.separator + "static" + File.separator + "js" + File.separator
                    + "appjs" + File.separator+ packageName + File.separator + classname + File.separator + "edit.js";
		}

//		if(template.contains("menu.sql.vm")){
//			return className.toLowerCase() + "_menu.sql";
//		}
		
		return null;
	}
}

vim插件_lookupfile_genutils

  • 2011年04月25日 21:14
  • 52KB
  • 下载

C#.NET实体代码生成工具,支持Access,MSSQLServer!实现数据库所有操作!

C#.NET实体代码生成工具,支持Access,MSSQLServer Microsoft Office Access 2003 实体类生成说明:1、打开.mdb数据库文件。2、“工具”—>“选项”—...
  • lantounet
  • lantounet
  • 2010-02-22 13:30:00
  • 1219

AutoCode 代码生成器 测试版

  • 2012年07月26日 18:15
  • 79KB
  • 下载

vim插件合集vim插件合集

  • 2009年12月03日 00:12
  • 253KB
  • 下载

jdbc工具类-生成domain实体

最近两天项目里遇到一个需求,要求将数据库里某些表的某些字段,加密,但是还要保证能及时还原回去.需求,很简单,但是写的时候,也遇到了一些问题,主要是oracle数据库使用数据库查询数据库时,result...
  • do_bset_yourself
  • do_bset_yourself
  • 2017-04-30 20:27:19
  • 488

Hibernate之自动生成工具

Hibernate总的来说无非就是维护javabena(pojo)与数据库表的映射工具,如果我们知道javaben,hbm文件,数据库schema三者中的一个就可以生成另外两个文件,MyEclipse...
  • zxc123e
  • zxc123e
  • 2015-07-11 20:28:54
  • 3239

给 Web 开发者的 25 款最有用的 AngularJS 工具

转自:http://www.oschina.net/news/60200/bestl-angularjs-tools AngularJS 是一种新 JavaScript 框架,目的是降低...
  • sqzhao
  • sqzhao
  • 2015-10-08 14:10:10
  • 1302

黑马出品代码生成器,超级好用,推荐

非常好用的代码生成器,最新版,传智播客出品,支持多种代码模板生成, 包括前端页面,csdn首发. 支持springboot+springdatajpa微服务; ssh+angularjs+boo...
  • m0_37609579
  • m0_37609579
  • 2018-01-27 17:22:18
  • 147

常用代码生成工具汇总(转)

1.1 CodeSmith 一款人气很旺国外的基于模板的dotnet代码生成器 官方网站:http://www.codesmithtools.com 官方论坛:http://foru...
  • xgc007
  • xgc007
  • 2016-11-01 17:09:23
  • 11401

代码生成器(根据数据表生成)

  • 2011年06月18日 15:27
  • 172KB
  • 下载
收藏助手
不良信息举报
您举报文章:代码生成器工具类GenUtils
举报原因:
原因补充:

(最多只允许输入30个字)