自定义一键创建controller,service,serviceImpl,mapper

2024-01-11 06:08

本文主要是介绍自定义一键创建controller,service,serviceImpl,mapper,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

//在开发过程中比如创建controller(控制层)我们避免不了的重复创建接口捕获异常为接口注释,这些虽然在编译器可以生成,但是总是不那么自由,尤其不符合个人习惯,因此我自己定义了一套,可以指定地址,指定名称,可以创建单个,也可以一次都创建,完全是为了自己的开发需要:

这个要额外的一个jar包mysql-connector-java-5.1.34.jar,因为在创建pojo类时,我是直接通过访问数据的dll文件读出表的数据结构的。

import java.io.File;
import java.io.FileOutputStream;
import java.io.PrintWriter;
import java.util.ArrayList;
import java.util.Date;
import java.util.List;
import java.sql.*;/*** Created by ChaoZhang on 2019-03-14 10:55*/public class create {/*** @type* all* domain* service* serviceImpl* ctrl* mapper* mapper.xml*/public static String type = "all";   //创建类型public static final String path = "E:\\CreateDomainServiceMapper\\src\\";   //创建路径及内容public static final String fileName = "SpaceAvShare";  //创建的文件的名字public static final String owner = "ChaoZhang";     //注释作者public static final Date date = new Date();     //创建时间static class classBuffer{public File file;public StringBuffer buffer;classBuffer(File file, StringBuffer buffer){this.file = file;this.buffer = buffer;}}/*** 自定义创建作者和注释加入到缓冲并返回* example* created by ChaoZhang onThu Mar 14 14:05:05 CST 2019*/public static StringBuffer writeOwner(){StringBuffer buffer = new StringBuffer();buffer.append("/**\r\n");buffer.append(" *created by " + owner + " on " + date + "\r\n");buffer.append(" */\r\n");buffer.append("\r\n");return buffer;}/*** 自定义创建class或者interface加入到缓冲并返回* @return* @throws Exception*/public static StringBuffer writeClassOrInterface(StringBuffer buffer) throws Exception{if(type.equals(new String("domain"))){buffer.append("public class " + fileName + " {" + "\r\n");JdbcConnection jdbcConnection = new JdbcConnection();System.out.println("*** writeClassOrInterface " + JdbcConnection.result.toString());buffer.append(JdbcConnection.result.toString());}else if(type.equals(new String("service"))){buffer.append("public interface " + fileName + "Service" + " {");}else if(type.equals(new String("ctrl"))){buffer.append("@Controller\r\n");buffer.append("@RequestMapping(value = \"\")\n");buffer.append("public class " + fileName + "Ctrl" + " {");buffer.append("\r\n\r\n");buffer.append("/*JSONObject jsonObject = new JSONObject();\n" +"    Integer state = Integer.valueOf(1000);\n" +"        try{\n" +"\n" +"    }catch (Exception e){\n" +"        e.printStackTrace();\n" +"        jsonObject.put(\"msg\", \"sql报错\");\n" +"        jsonObject.put(\"erro\", e.getCause());\n" +"        state = Integer.valueOf(2000);\n" +"    }\n" +"        jsonObject.put(\"state\", state);\n" +"        return jsonObject;*/");}else if(type.equals(new String("serviceImpl"))){buffer.append("@Service\r\n");buffer.append("public class " + fileName + "ServiceImpl " + "implements " + fileName + "Service" + " {");}else if(type.equals(new String("mapper"))){buffer.append("public interface " + fileName + "Mapper" + " {");}if(type.equals(new String("xml"))){buffer.append("<?xml version=\"1.0\" encoding=\"UTF-8\" ?>\r\n");buffer.append("<!DOCTYPE mapper PUBLIC \"-//mybatis.org//DTD Mapper 3.0//EN\" \"http://mybatis.org/dtd/mybatis-3-mapper.dtd\" >\r\n");buffer.append("<mapper namespace=\"com.vv.space.mapper.DeviceUserMapper\" >\r\n");buffer.append("\r\n\r\n");buffer.append("</mapper>\r\n");return buffer;}buffer.append("\r\n");buffer.append("\r\n");buffer.append("}");return buffer;}/*** 创建pojo类* domain文件夹*/public static classBuffer createDomain(){File file = new File(path + fileName + ".java");//写文件注释和创建者StringBuffer buffer = writeOwner();classBuffer classBuffer = new classBuffer(file, buffer);return classBuffer;}/*** 创建业务service* service文件夹*/public static classBuffer createService(){File file = new File(path + fileName + "Service" +".java");//写文件注释和创建者StringBuffer buffer = writeOwner();classBuffer classBuffer = new classBuffer(file, buffer);return classBuffer;}/*** 创建Dao层服务* mapper文件夹*/public static classBuffer createMapper(){File file = new File(path + fileName + "Mapper" + ".java");//写文件注释和创建者StringBuffer buffer = writeOwner();classBuffer classBuffer = new classBuffer(file, buffer);return classBuffer;}/*** 创建业务实现类* impl文件夹*/public static classBuffer createserviceImpl(){File file = new File(path + fileName + "ServiceImpl" + ".java");//写文件注释和创建者StringBuffer buffer = writeOwner();classBuffer classBuffer = new classBuffer(file, buffer);return classBuffer;}/*** 创建控制层实现类* controller文件夹*/public static classBuffer createCtrl(){File file = new File(path + fileName + "Ctrl" + ".java");//写文件注释和创建者StringBuffer buffer = writeOwner();classBuffer classBuffer = new classBuffer(file, buffer);return classBuffer;}/*** 创建.xml文件* @throws Exception*/public static classBuffer createXml(){File file = new File(path + fileName + "Mapper" + ".xml");//写文件注释和创建者StringBuffer buffer = writeOwner();classBuffer classBuffer = new classBuffer(file, buffer);return classBuffer;}public static void create() throws Exception{classBuffer classBuffer = null;switch (type){case "domain":classBuffer = createDomain();break;case "service":classBuffer = createService();break;case "serviceImpl":classBuffer = createserviceImpl();break;case "ctrl":classBuffer = createCtrl();break;case "mapper":classBuffer = createMapper();break;case "xml":classBuffer = createXml();break;default:System.out.println("未知类型");}if(classBuffer.file.exists()){System.out.println("*** 该" + type + "文件已经存在 ***");return ;}else{classBuffer.file.createNewFile();   //创建文件//创建class or interfaceStringBuffer buffer1 = writeClassOrInterface(classBuffer.buffer);FileOutputStream fs = new FileOutputStream(classBuffer.file);   //创建输出流输出到文件PrintWriter pw = new PrintWriter(fs);   //创建打印对象将字符写入输出流pw.write(buffer1.toString());    //将字符写入输出流pw.flush();     //强制将缓冲全部输出到指定文件pw.close();}}//定义一个连接类static class JdbcConnection{//创建一个用于连接的对象Connection ct = null;//创建一个用于发送sql语句的对象PreparedStatement ps = null;//创建一个用于接收结果集的对象ResultSet rs = null;//属性public static StringBuffer result = new StringBuffer("");//默认构造函数public JdbcConnection(){try {//加载驱动Class.forName("org.gjt.mm.mysql.Driver");//得到连接ct = DriverManager.getConnection("jdbc:mysql://114.112.92.135:3307/space?zeroDateTimeBehavior=convertToNull&amp;useUnicode=true&amp;characterEncoding=utf8","songod", "6Kx2n9usEP96K" );//查询String str = "SELECT COLUMN_NAME name , COLUMN_TYPE type, COLUMN_COMMENT comment FROM information_schema.COLUMNS WHERE TABLE_SCHEMA = 'space' AND TABLE_NAME = 'space_av';";ps = ct.prepareStatement(str);//得到结果rs = ps.executeQuery();String s = null;while(rs.next()){s = "private " + rs.getString(2) + " " + rs.getString(1) + ";" + "   //" + rs.getString(3);System.out.println("private " + rs.getString(2) + " " + rs.getString(1) + ";" + "   //" + rs.getString(3));this.result.append("\r\n");this.result.append("\r\n");this.result.append("    ");this.result.append(s);this.result.append("\r\n");}} catch (Exception e) {// TODO: handle exceptione.printStackTrace();}finally{try {//关闭资源if(rs != null){rs.close();}if(ps != null){ps.close();}if(ct != null){ct.close();}} catch (Exception e2) {// TODO: handle exceptione2.printStackTrace();}}}}public static void main(String[] args) throws Exception{/*** 创建*/System.out.println("*** 开始创建 ***");List<String> list = new ArrayList<String>();if(type.equals("all")){list.add("domain");list.add("service");list.add("ctrl");list.add("mapper");list.add("serviceImpl");list.add("xml");}else{create();}for(String s:list){type = s;create();}System.out.println("*** 创建完成 ***");}}

比如我要创建的叫SpaceAvShare那么如下图:

从pojo类,ctrl,mapper,service都创建好了,这里要提一下创建pojo类需要连接数据库的连接,我将数据库的某个表的dll文件读出创建pojo类

很简单,完全符合我自己的习惯

 

这篇关于自定义一键创建controller,service,serviceImpl,mapper的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/593390

相关文章

Linux线程之线程的创建、属性、回收、退出、取消方式

《Linux线程之线程的创建、属性、回收、退出、取消方式》文章总结了线程管理核心知识:线程号唯一、创建方式、属性设置(如分离状态与栈大小)、回收机制(join/detach)、退出方法(返回/pthr... 目录1. 线程号2. 线程的创建3. 线程属性4. 线程的回收5. 线程的退出6. 线程的取消7.

SpringBoot+EasyExcel实现自定义复杂样式导入导出

《SpringBoot+EasyExcel实现自定义复杂样式导入导出》这篇文章主要为大家详细介绍了SpringBoot如何结果EasyExcel实现自定义复杂样式导入导出功能,文中的示例代码讲解详细,... 目录安装处理自定义导出复杂场景1、列不固定,动态列2、动态下拉3、自定义锁定行/列,添加密码4、合并

创建Java keystore文件的完整指南及详细步骤

《创建Javakeystore文件的完整指南及详细步骤》本文详解Java中keystore的创建与配置,涵盖私钥管理、自签名与CA证书生成、SSL/TLS应用,强调安全存储及验证机制,确保通信加密和... 目录1. 秘密键(私钥)的理解与管理私钥的定义与重要性私钥的管理策略私钥的生成与存储2. 证书的创建与

python如何创建等差数列

《python如何创建等差数列》:本文主要介绍python如何创建等差数列的问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录python创建等差数列例题运行代码回车输出结果总结python创建等差数列import numpy as np x=int(in

Java实现自定义table宽高的示例代码

《Java实现自定义table宽高的示例代码》在桌面应用、管理系统乃至报表工具中,表格(JTable)作为最常用的数据展示组件,不仅承载对数据的增删改查,还需要配合布局与视觉需求,而JavaSwing... 目录一、项目背景详细介绍二、项目需求详细介绍三、相关技术详细介绍四、实现思路详细介绍五、完整实现代码

一文详解Java Stream的sorted自定义排序

《一文详解JavaStream的sorted自定义排序》Javastream中的sorted方法是用于对流中的元素进行排序的方法,它可以接受一个comparator参数,用于指定排序规则,sorte... 目录一、sorted 操作的基础原理二、自定义排序的实现方式1. Comparator 接口的 Lam

怎么用idea创建一个SpringBoot项目

《怎么用idea创建一个SpringBoot项目》本文介绍了在IDEA中创建SpringBoot项目的步骤,包括环境准备(JDK1.8+、Maven3.2.5+)、使用SpringInitializr... 目录如何在idea中创建一个SpringBoot项目环境准备1.1打开IDEA,点击New新建一个项

如何使用Maven创建web目录结构

《如何使用Maven创建web目录结构》:本文主要介绍如何使用Maven创建web目录结构的问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录创建web工程第一步第二步第三步第四步第五步第六步第七步总结创建web工程第一步js通过Maven骨架创pytho

MySQL 用户创建与授权最佳实践

《MySQL用户创建与授权最佳实践》在MySQL中,用户管理和权限控制是数据库安全的重要组成部分,下面详细介绍如何在MySQL中创建用户并授予适当的权限,感兴趣的朋友跟随小编一起看看吧... 目录mysql 用户创建与授权详解一、MySQL用户管理基础1. 用户账户组成2. 查看现有用户二、创建用户1. 基

mapstruct中的@Mapper注解的基本用法

《mapstruct中的@Mapper注解的基本用法》在MapStruct中,@Mapper注解是核心注解之一,用于标记一个接口或抽象类为MapStruct的映射器(Mapper),本文给大家介绍ma... 目录1. 基本用法2. 常用属性3. 高级用法4. 注意事项5. 总结6. 编译异常处理在MapSt