肝了一个半月的Java项目快速开发脚手架Chewing
前言
闲来无事,整一个 Java 项目快速开发脚手架。 正文一、简介
Chewing 是一个简单的 Java 项目快速开发脚手架。既适合需要开发小型项目的小伙伴使用,也适合刚入门的新手用来学习一些常用的技术。 二、源码
源码地址:https://github.com/jingqueyimu/chewing。 三、核心技术1、后端SpringBoot:Web 应用框架。 MyBatis:持久层框架。 MySQL:关系型数据库。 Redis:缓存数据库。 RabbitMQ:消息队列中间件。 2、前端Thymeleaf:模板引擎。 Bootstrap:UI 框架。 四、环境部署1、准备工作JDK 1.8 MySQL 5.7 Maven 3.x Redis RabbitMQ 2、必要配置application.properties 配置文件:数据库、Redis、RabbitMQ、邮箱等配置。 config/myconfig.properties 配置文件:系统相关的自定义配置。 五、项目介绍1、文件结构src/main/java |— com.jingqueyimu |— annotation // 注解 |— aspect // 切面 |— config // 配置 |— constant // 常量 |— context // 上下文 |— controller // 控制层 |— exception // 异常 |— factory // 工厂 |— filter // 过滤器 |— handler // 处理器 |— init // 初始化 |— interceptor // 拦截器 |— mapper // 持久层 |— model // 数据模型 |— mq // 消息队列 |— schedule // 调度 |— service // 服务层 |— util // 工具 MyAppcation.java // 应用启动类 src/main/resources |— config // 配置文件 |— mapper // 映射文件 |— static // 静态文件 |— templates // 页面文件 application.properties // 应用配置文件 quartz.properties // 调度配置文件 2、代码说明(1)路由/api/xxx:需要用户登录。 /console/xxx:需要管理员登录,登录、登出等部分接口除外。 (2)接口规范页面请求:GET、URL 参数。 接口请求:POST、JSON 参数。 (3)数据库初始化初始化配置文件:config/dbinit.json。 配置初始化标识及 SQL 语句。
初始化示例: [ { "initKey": "site_config_20210110", "sqls": [ "INSERT INTO t_site_config (id, code, name, content, description, public_flag, gmt_create) VALUES(NULL, "site_record_no", "网站备案号", "备案号", "网站备案号", true, NOW());" ] } ] (4)文件上传下载上传单个文件:/file/upload。 上传多个文件:/file/uploads。 下载文件:/file/download。 (5)Excel 导入导出Excel 导入导出方法:ExcelUtil.importExcel()、ExcelUtil.exportExcel()。 Excel 导入导出处理器接口:IExcelImportHandler、IExcelExportHandler。
导入示例: String msg = null; try { String[] keys = new String[] {"username", "realName", "mobile"}; msg = ExcelUtil.importExcel(file.getInputStream(), keys, new IExcelImportHandler() { @Override public void handle(JSONObject data) { if (StringUtils.isBlank(data.getString("username"))) { throw new RuntimeException("用户名不能为空"); } if (StringUtils.isBlank(data.getString("mobile"))) { throw new RuntimeException("手机号不能为空"); } // 业务处理 } }); log.info(msg); } catch (IOException e) { e.printStackTrace(); }
导出示例: ServletOutputStream os = null; try { String fileName = "用户列表"; ... // 用户列表数据 List list = userService.list(params); // 表头 String[] headers = new String[] {"编号 ", "用户名", "姓名", "手机号", "邮箱", "注册方式", "注册时间", "上次登录时间", "是否VIP"}; os = response.getOutputStream(); // 导出 ExcelUtil.exportExcel(fileName, list, headers, os, new IExcelExportHandler() { @Override public List