知了小站 - IT人的小站 - eladmin开源 2022-08-02T15:18:00+08:00 Typecho https://izlzl.com/feed/atom/tag/eladmin/ <![CDATA[ELADMIN 项目官网域名更换通知与加群答案]]> https://izlzl.com/archives/1646.html 2022-08-02T15:18:00+08:00 2022-08-02T15:18:00+08:00 知了小站 https://izlzl.com 为方便访问,已将 ELADMIN 官网域名更换为 eladmin.vip

访问老域名 el-admin.vip 会重定向到新域名 eladmin.vip

QQ交流群:891137268947578238659622532

入群答案:eladmin.vip

有关 ELADMIN 的更多问题访问

https://eladmin.vip/pages/020101/

]]>
<![CDATA[基于 Spring Boot 的前后端分离脚手架 ELADMIN]]> https://izlzl.com/archives/66.html 2021-06-29T14:56:00+08:00 2021-06-29T14:56:00+08:00 知了小站 https://izlzl.com 项目介绍

EL-ADMIN 基于 Spring Boot 2.1.0 、Spring Boot Jpa、 JWT、Spring Security、Redis、Vue、Element-UI 的前后端分离的后台管理系统, 项目采用按功能分模块的开发方式,权限控制采用 RBAC 思想,支持数据字典与数据权限管理,支持一键生成前后端代码,支持前端菜单动态路由等

2023-06-26 发布了 mybatis-plus 版本: https://github.com/elunez/eladmin-mp

主要特性

  1. 使用最新技术栈,社区资源丰富。
  2. 高效率开发,代码生成器可一键生成前后端代码
  3. 支持数据字典,可方便地对一些状态进行管理
  4. 支持接口限流,避免恶意请求导致服务层压力过大
  5. 支持接口级别的功能权限与数据权限,可自定义操作
  6. 自定义权限注解与匿名接口注解,可快速对接口拦截与放行
  7. 对一些常用地前端组件封装:表格数据请求、数据字典等
  8. 前后端统一异常拦截处理,统一输出异常,避免繁琐的判断
  9. 支持在线用户管理与服务器性能监控,支持限制单用户登录
  10. 支持运维管理,可方便地对远程服务器的应用进行部署与管理

主要功能

  1. 用户管理:提供用户的相关配置,新增用户后,默认密码为123456
  2. 角色管理:对权限与菜单进行分配,可根据部门设置角色的数据权限
  3. 菜单管理:已实现菜单动态路由,后端可配置化,支持多级菜单
  4. 部门管理:可配置系统组织架构,树形表格展示
  5. 岗位管理:配置各个部门的职位
  6. 字典管理:可维护常用一些固定的数据,如:状态,性别等
  7. 系统日志:记录用户操作日志与异常日志,方便开发人员定位排错
  8. SQL监控:采用druid 监控数据库访问性能,默认用户名admin,密码123456
  9. 定时任务:整合Quartz做定时任务,加入任务日志,任务运行情况一目了然
  10. 代码生成:高灵活度生成前后端代码,减少大量重复的工作任务
  11. 邮件工具:配合富文本,发送html格式的邮件
  12. 七牛云存储:可同步七牛云存储的数据到系统,无需登录七牛云直接操作云数据
  13. 支付宝支付:整合了支付宝支付并且提供了测试账号,可自行测试
  14. 服务监控:监控服务器的负载情况
  15. 运维管理:一键部署你的应用

项目结构

- eladmin-common 公共模块
    - annotation 为系统自定义注解
    - aspect 自定义注解的切面
    - base 提供了Entity、DTO基类和mapstruct的通用mapper
    - config 自定义权限实现、redis配置、swagger配置、Rsa配置等
    - exception 项目统一异常的处理
    - utils 系统通用工具类
- eladmin-system 系统核心模块(系统启动入口)
    - config 配置跨域与静态资源,与数据权限
        - thread 线程池相关
    - modules 系统相关模块(登录授权、系统监控、定时任务、运维管理等)
- eladmin-logging 系统日志模块
- eladmin-tools 系统第三方工具模块
- eladmin-generator 系统代码生成模块

项目地址

码云作为国内同步仓库,可解决Github克隆缓慢的问题,两个平台的代码都是同步更新的,按需选择 ,Bug 提交请在 Github 创建 Issues

/后端源码前端源码
Githubhttps://github.com/elunez/eladminhttps://github.com/elunez/eladmin-web
Giteehttps://gitee.com/elunez/eladminhttps://gitee.com/elunez/eladmin-web

反馈交流

开发文档 https://eladmin.vip

为了统一管理,现已关闭 Gitee 的 Issues 功能

使用中遇到问题或者 Bug 可以在 Github 上提 Issues

QQ交流群:一群: 891137268 、二群:947578238、三群:659622532

项目预览

预览地址:https://eladmin.vip/demo

账号密码:admin / 123456
登录界面

kqhtc6kp.png

用户管理

kqhpdzf8.png

菜单管理

kqhpefkb.png

定时任务

kqhpf4xo.png

代码生成

kqhpg1sl.png

更多功能,点击预览地址体验:https://eladmin.vip/demo

]]>
<![CDATA[利用 Nginx 的 Gzip 模块解决 Vue 首屏加载缓慢的问题]]> https://izlzl.com/archives/1260.html 2021-02-27T22:55:00+08:00 2021-02-27T22:55:00+08:00 知了小站 https://izlzl.com 通过 Nginx 的 Gize 模块拦截请求,并且对相应的资源进行压缩,已达到减少文件体积加快文件访问速度的目的,使用 Nginx 的 Gizp 模块不需要重新编译,直接开启即可。

基本配置

在 server 中加入如下代码

# 开启gzip
gzip  on;
# 低于1kb的资源不压缩
gzip_min_length 1k;
# 设置压缩所需要的缓冲区大小
gzip_buffers 4 16k;
# 压缩级别【1-9】,越大压缩率越高,同时消耗cpu资源也越多,建议设置在4左右。
gzip_comp_level 6;
# 需要压缩哪些响应类型的资源,缺少的类型自己补。
gzip_types text/plain application/javascript application/x-javascript text/javascript text/css application/xml;
# 配置禁用gzip条件,支持正则。此处表示ie6及以下不启用gzip(因为ie低版本不支持)
gzip_disable "MSIE [1-6]\.";
# 是否添加“Vary: Accept-Encoding”响应头,
gzip_vary on;
# 设置gzip压缩针对的HTTP协议版本,没做负载的可以不用
# gzip_http_version 1.0;

查看效果

response headers 中的 Content-Encodinggzip 就代表开启成功

前后对比

未开启 Gzip 的文件大小与加载速度

开启 Gzip 后的文件大小与加载速度

前后速度提升明显

完整配置

附上完整的 Nginx https + Gzip 配置

server {
       listen 443 ssl http2;
       server_name el-admin.xin www.el-admin.xin;

       # 证书配置
        ssl_certificate  /etc/nginx/cert/el-admin-xin/el-admin.xin_chain.crt;    
       ssl_certificate_key  /etc/nginx/cert/el-admin-xin/el-admin.xin_key.key;

        # DHE密码器的Diffie-Hellman参数,需要openssl手动生成
        # openssl命令:openssl dhparam -dsaparam -out /home/nginx/cert/el-admin-vip/dhparam.pem 4096
        ssl_dhparam /etc/nginx/cert/el-admin-xin/dhparam.pem;

        # 开启OCSP Stapling,由服务器验证证书在线状态,提高TLS握手效率
        ssl_stapling on;
        ssl_stapling_verify on;

        # 开启HSTS,缓存http重定向到https,以防止中间人攻击
        add_header Strict-Transport-Security "max-age=63072000;" always;

        # 开启TLS False Start
        ssl_prefer_server_ciphers on;
    
        # 中等兼容程度,Mozilla推荐配置
        ssl_ciphers  ECDHE-ECDSA-AES128-GCM-SHA256:ECDHE-RSA-AES128-GCM-SHA256:ECDHE-ECDSA-AES256-GCM-SHA384:ECDHE-RSA-AES256-GCM-SHA384:ECDHE-ECDSA-CHACHA20-POLY1305:ECDHE-RSA-CHACHA20-POLY1305:DHE-RSA-AES128-GCM-SHA256:DHE-RSA-AES256-GCM-SHA384;
    
        # 中等兼容程度,Mozilla推荐配置
        ssl_protocols TLSv1.1 TLSv1.2 TLSv1.3;
    
        # 由客户端保存加密后的session信息
        ssl_session_tickets on;
    
        # 缓存SSL
        ssl_session_cache shared:SSL:10m;
        ssl_session_timeout 1d;
    
        # 长链接
        keepalive_timeout  70;
    
        #减少点击劫持,禁止在iframe中加载
        add_header X-Frame-Options DENY;

       # 开启gzip    
        gzip  on;
        # 低于1kb的资源不压缩
       gzip_min_length 1k;
       # 设置压缩所需要的缓冲区大小
       gzip_buffers 4 16k;
       # 压缩级别【1-9】,越大压缩率越高,同时消耗cpu资源也越多,建议设置在4左右。
       gzip_comp_level 4;
       # 需要压缩哪些响应类型的资源,缺少自己补。
       gzip_types text/css text/javascript application/javascript;
       # 配置禁用gzip条件,支持正则。此处表示ie6及以下不启用gzip(因为ie低版本不支持)
       gzip_disable "MSIE [1-6]\.";
       # 是否添加“Vary: Accept-Encoding”响应头,
       gzip_vary on;
        
        # 根目录
        location / {
          root   /usr/share/nginx/html/eladmin/dist;
          index  index.html;
          try_files $uri $uri/ @router;
          proxy_set_header Host $host;
          proxy_set_header X-Real-IP $remote_addr;
          proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
       }
    
       location @router {
          rewrite ^.*$ /index.html last;
       }
}

server {
       listen       80;
       server_name  el-admin.xin;
       return 301 https://el-admin.xin$request_uri;
}
]]>
<![CDATA[EL-ADMIN 邮箱配置之使用 QQ 邮箱发送邮件]]> https://izlzl.com/archives/1246.html 2021-02-08T21:04:00+08:00 2021-02-08T21:04:00+08:00 知了小站 https://izlzl.com EL-ADMIN 配置邮箱后,发送邮件提示:邮箱发送邮件失败:AuthenticationFailedException

issues 地址:https://github.com/elunez/eladmin/issues/571

修复步骤

1、在QQ邮箱中 开启 IMAP/SMTP服务,获取独立密码

2、在邮件工具里面配置邮箱信息

参数说明

1、发件人用户名:用户收信时显示的发件人名称

2、邮箱密码:QQ邮箱需要为SMTP服务单独设置密码

3、QQ 邮箱的 SMTP 地址:smtp.qq.com
4、SMTP 使用默认的 465 即可

修改代码

定位到:eladmin-tools/src/main/java/me/zhengjie/service/impl/EmailServiceImpl.java

修改第 72 行

// 设置用户
String user = emailConfig.getFromUser().split("@")[0];
account.setUser(user);

重新启动项目即可

]]>
<![CDATA[EL-ADMIN V2.5 版本发布,新增多项实用功能,代码多项优化]]> https://izlzl.com/archives/1234.html 2020-06-08T20:01:00+08:00 2020-06-08T20:01:00+08:00 知了小站 https://izlzl.com V2.4版本现基本稳定,V2.5版本都是基于现版本进行Bug修复与优化调整,新版本更新内容如下

后端改动

新增功能

  1. 加入审计功能,继承 BaseEntity 后自动写入创建时间、修改时间、创建人、更新人,详见 AuditorConfig
  2. Token 自动续期功能,用户在快过期的时间内操作活跃,可将 Token 过期时间延长,详见 TokenFilter
  3. 数据权限注解的实现,摈弃在 Controller 的操作方式,采用 @DataPermission 注解实现,详见 后端手册
  4. 新的服务监控实现,后端采用 oshi,前端采用 echarts 做可视化借鉴了[宝塔监控],详见 预览地址
  5. 定时任务创建时支持添加异常通知人,当定时任务执行失败发送邮件通知 [支持多邮箱], 详见 后端手册
  6. 定时任务支持添加子任务,当主任务执行完后自动执行子任务 [支持多子任务,顺序执行], 详见 后端手册

    细节优化

    结构优化

数据库脚本选择,见 脚本指南

  1. 所有表按功能加入前缀:sys、tool、mnt 方便后续管理维护
  2. 所有表字段的主键改为: 表名_id,方便与关联表的 id 统一
  3. 所有表加入 create_by、update_by、create_time、update_time 字段,便于审计
  4. 去除无用字段,加入必要索引加快查询速度,去除外键改为程序控制
  5. sys_user 表中加入 is_admin 字段用户区分是否为管理员
  6. 删除 avatar 头像表,将头像的的头像名称与路径存入 sys_user 表

代码优化

  1. 去除首页 ip,pv 统计,此功能对于后台管理显得多余
  2. 邮箱验证功能的验证码改为存储在 Redis 中,删除了原来从数据库中取的逻辑代码
  3. 修改不规范的字段名/包名,将 mapper 包改为 mapstruct,避免与 mybatis 的 mapper 冲突
  4. 重新设计缓存功能,去除不必要的缓存,去除监控模块,将新服务监控管理移入 system 模块
  5. 用户管理、角色管理、菜单管理、部门管理中树形均采用懒加载方式实现,避免大量的数据导致页面卡顿
  6. 加入RsaUtils工具类解决Hutool工具Rsa解密过慢的问题,IP 归属地查询改为用太平洋IP地址查询接口
  7. TokenFilter Token 验证逻辑优化,对于已放行的接口不去验证 Token 合法性
  8. 文件上传优化,加入 FileProperties 配置,根据系统选择上传目录
  9. 代码生成器前端 index.vue 模板查询优化,取消以前的下拉方式查询 详见

错误修复

  1. 运维管理解决不能向不同服务器部署应用的缺陷 #347
  2. 运维管理解决部署到linux服务器路径拼接不正确问题 #347
  3. 运维管理解决每次连接不同服务器都默认访问第一台服务器的问题 #347
  4. 当前用户如果没有任何权限时,在输入用户名后,刷新验证码会抛IllegalArgumentException #333
  5. 修复不存在账号登录时userService.findByName 抛出异常,loadUserByUsername未捕获处理的Bug 详见

前端改动

新增功能

  1. 同一界面内,多CRUD共存,支持自定义数据id字段名 详见
  2. 字典管理使用CRUD组件改写,CRUD组件增加对table延迟实例化支持,完善组件注册、注销 #83
  3. 登录页背景使用本地图片,服务监控采用 v-echarts 实现
  4. 用户管理、角色管理、菜单管理、部门管理,列表和弹窗数据懒加载
  5. 用户头像裁剪上传节省空间 详见
  6. @crud/CRUD.operation中增加对列隐藏(初始阶段)支持 #95
  7. @crud/CRUD.operation中增加对列忽略支持 #95
  8. @crud/CRUD.operation中列可见性控制选项顺序跟随表格列顺序变更 #95

细节优化

  1. 优化主题切换按钮下移问题、优化tabs被footer遮挡问题、优化主题在页面刷新后重置的问题
  2. 取消crud.props记录tableColumns,调整表格列可见性控制时插入位置计算 #95
  3. 修改Token过期的提示,由原来的弹窗提示改为登录界面消息提示 详见

错误修复

  1. 修复V2.4版本中路由懒加载问题 详见
  2. 修复菜单管理选择图标,backspace删除时不过滤数据 详见
  3. 修复重定向到登录页,登录后参数丢失问题,比如文章详情/article?id=6 #94
  4. 修复首页搜索菜单外链无法点击跳转问题 By RuoYi-Vue
  5. 解决部署管理和数据库管理,选择记录不能启用自定义按钮的问题 详见
  6. 修复字典管理模块点击编辑后再点击新增报错的问题 #366

脚本指南

项目根目录的 sql 文件夹内提供了本次数据库变更的脚本,脚本如何选择,以及执行的顺序如下

操作数据库属于危险行为,请勿用于生产库,请事先做好备份!!!

初次使用

eladmin.sql 为 eladmin 项目完整的 sql 脚本,适合于初次使用的用户

更新迭代

对于老版本的,可以按下面的顺序执行

  1. 删除所有外键.sql
  2. 表名修改.sql
  3. code_ 相关表字段调整.sql
  4. mnt_ 相关表字段调整.sql
  5. tool_ 相关表字段调整.sql
  6. sys_ 相关表字段调整.sql
  7. 用户岗位改动.sql
  8. 相关数据更新.sql
  9. 索引相关.sql
  10. 删除无用表.sql

脚本已经提供,其他的就需要自己慢慢调试了,祝成功!

项目源码

开发文档:https://el-admin.vip

预览地址:https://el-admin.xin

后端源码前端源码
Githubhttps://github.com/elunez/eladminhttps://github.com/elunez/eladmin-web
码云https://gitee.com/elunez/eladminhttps://gitee.com/elunez/eladmin-web
]]>
<![CDATA[快速解决 npm 安装 node-sass 速度慢/错误的问题]]> https://izlzl.com/archives/1219.html 2020-02-20T09:58:00+08:00 2020-02-20T09:58:00+08:00 知了小站 https://izlzl.com 可通过配置淘宝的镜像源解决,首先配置淘宝的镜像源

npm config set registry https://registry.npm.taobao.org

然后在 ~/.npmrc 加入下面内容

sass_binary_site=https://npm.taobao.org/mirrors/node-sass/

.npmrc 文件位于

win:C:\Users\[你的账户名称]\.npmrc
linux:直接使用 vi ~/.npmrc

完整配置如图

]]>
<![CDATA[EL-ADMIN v2.4 发布,升级 cli3,新增监控模块,运维管理等]]> https://izlzl.com/archives/1210.html 2019-12-23T10:15:00+08:00 2019-12-23T10:15:00+08:00 知了小站 https://izlzl.com EL-ADMIN 基于 Spring Boot 2.1.0 、 Jpa、 Spring Security、redis、Vue 的前后端分离的后台管理系统,项目采用分模块开发方式, 权限控制采用 RBAC,支持数据字典与数据权限管理,支持一键生成前后端代码,支持前端菜单动态路由。

v2.4 版本更新内容如下

后端

1、新增服务监控模块 eladmin-monitor,监控服务器的负载情况 (by @zhy6599)

2、代码生成器优化,支持配置更多信息,支持打包下载与预览生成

(1) 界面

(2) 配置

(3) 预览

3、加入了运维管理 (by @zhy6599)

4、用户加入昵称与性别字段

5、免费图床支持同步功能

6、新增清空日志功能,需要相应的权限才能操作 (#217 by @zoulejiu)

7、security 优化,密码加密方式采用BCryptPasswordEncoder方式:SHA-256 +随机盐+密钥对密码进行加密

7、前后端用户登陆密码rsa加密,后端解密,避免撞库

8、@Query新增 NOT_EQUALBETWEENNOT_NULL查询

9、匿名访问统一使用 @AnonymousAccess

去除 @PreAuthorize("hasRole('anonymous')")、@PreAuthorize("@el.check('anonymous')") 的匿名访问效果

10、新增单点登录,多设备登录 (#217 by @zoulejiu)

以最后登录为准,之前的登录都会被踢掉,可以使用single.login =false 关闭

11、代码优化,2.4版本完全遵循阿里巴巴代码规范

前端

1、前端升级为 vue-cli3 ,加入主题配置,目录结构优化

2、移除 initData.js,封装 crud.js ,只需要引入该 js 即可实现所有增删改查的功能(详情查看源码)

3、封装crud通用组件,建议使用,2.4 前端页面几乎都是使用这种形式 (#57 by @moxun1639)

(1) 组件路径

(2) 如何使用

<template>
  <div class="app-container">
    <!--工具栏-->
    <div class="head-container">
      <div v-if="crud.props.searchToggle">
        <!-- 搜索 -->
        <el-input v-model="query.value" clearable placeholder="输入搜索内容" style="width: 200px;" class="filter-item" @keyup.enter.native="crud.toQuery" />
        <!--略-->
        <rrOperation :crud="crud" />
      </div>
      <!--如果想在工具栏加入更多按钮,可以使用插槽方式, slot = 'left' or 'right'-->
      <crudOperation :permission="permission" />
      <!--表单组件-->
      <el-dialog :close-on-click-modal="false" :before-close="crud.cancelCU" :visible.sync="crud.status.cu > 0" :title="crud.status.title" width="500px">
        <!--略-->
        <div slot="footer" class="dialog-footer">
          <el-button type="text" @click="crud.cancelCU">取消</el-button>
          <el-button :loading="crud.cu === 2" type="primary" @click="crud.submitCU">确认</el-button>
        </div>
      </el-dialog>
      <!--表格渲染-->
      <el-table ref="table" v-loading="crud.loading" :data="crud.data" size="small" style="width: 100%;" @selection-change="crud.selectionChangeHandler">
        <el-table-column type="selection" width="55" />
        <el-table-column v-if="columns.visible('createTime')" prop="createTime" label="createTime">
          <template slot-scope="scope">
            <span>{{ parseTime(scope.row.createTime) }}</span>
          </template>
        </el-table-column>
        <el-table-column v-permission="['admin','genTest:edit','genTest:del']" label="操作" width="150px" align="center">
          <template slot-scope="scope">
            <udOperation :data="scope.row" :permission="permission" />
          </template>
        </el-table-column>
      </el-table>
      <!--分页组件-->
      <pagination />
    </div>
  </div>
</template>

<script>
import crudGenTest from '@/api/genTest'
import CRUD, { presenter, header, form, crud } from '@crud/crud'
import rrOperation from '@crud/RR.operation'
import crudOperation from '@crud/CRUD.operation'
import udOperation from '@crud/UD.operation'
import pagination from '@crud/Pagination'

// crud交由presenter持有
const defaultCrud = CRUD({ title: '测试生成', url: 'api/genTest', sort: 'id,desc', crudMethod: { ...crudGenTest }})
const defaultForm = { id: null, name: null, sex: null, createTime: null }
export default {
  name: 'GenTest',
  components: { pagination, crudOperation, rrOperation, udOperation },
  mixins: [presenter(defaultCrud), header(), form(defaultForm), crud()],
  data() {
    return {
      permission: {
        add: ['admin', 'genTest:add'],
        edit: ['admin', 'genTest:edit'],
        del: ['admin', 'genTest:del']
      },
      rules: {
        id: [
          { required: true, message: 'ID不能为空', trigger: 'blur' }
        ],
        name: [
          { required: true, message: '名称不能为空', trigger: 'blur' }
        ]
      },
      queryTypeOptions: [
        { key: 'name', display_name: '名称' },
        { key: 'sex', display_name: '性别' }
      ]
    }
  },
  methods: {
    // 获取数据前设置好接口地址
    [CRUD.HOOK.beforeRefresh]() {
      const query = this.query
      if (query.type && query.value) {
        this.crud.params[query.type] = query.value
      }
      return true
    }
  }
}
</script>

(3) 界面如下

3、异常日志详情加入代码高亮显示,生产环境移除console

4、其他升级可以查看演示页面

修复

1、修复查询时输入 []{} 符号报错的问题#185

2、修复本地存储预览关闭按钮被header遮挡的问题#188

3、修复Menu排序问题 (#194 by CCCY0)

4、修复ip2region 不会自动关闭连接问题 (#217 by @zoulejiu)

5、QueryHelp 中 RIGHT_LIKE 缺少 break 的问题 (#214 by jhpx)

指南

  • 新版本代码生成器:链接
  • 新版本服务监控:链接
  • 新版本运维管理:链接
  • 新版本免费图床:链接
  • 新版本@Query查询:链接
]]>
<![CDATA[EL-ADMIN v2.3 发布,新增在线用户管理,多项优化]]> https://izlzl.com/archives/1197.html 2019-11-04T17:16:00+08:00 2019-11-04T17:16:00+08:00 知了小站 https://izlzl.com EL-ADMIN 是基于 Spring Boot 2.1.0 、 Jpa、 Spring Security、Redis、Vue的前后端分离的权限管理系统,项目采用按功能分模块开发方式, 权限控制采用 RBAC 方式,前端菜单动态路由。新版更新内容如下:

后端

  1. 代码优化,优化大量Idea警告,代码更严谨 #134
  2. 加入实体基类(BaseEntity)、DTO基类(BaseDTO),按需继承 #137
  3. 新增基于Redis的在线用户管理,可强制下线用户 #6
  4. 新增退出登录接口,退出登录后Token不再有效
  5. 图形验证码更换,由随机验证码模式,改为算术验证
  6. 日志管理加入浏览器字段,获取Ip地址优化,局域网内支持获取到主机地址
  7. 菜单与权限调整,权限管理作为按钮存入菜单表
  8. 增加匿名访问注解,扩展PreAuthorize 匿名注解 #159
  9. 自定义权限校验,@PreAuthorize("@el.check('dept:list')"),根据个人习惯可自行选择
  10. 代码生成器优化,前后端默认添加导出功能,input时间组件自动判定
  11. 自定义异步线程池(重写spring默认线程池),使用自定义线程池执行定时任务,避免程序OOM
  12. 免费图床优化,通过MD5判断图片是否重复上传,如果图片存在则返回历史图片

前端

  1. 简化数据字典的使用,由混入改为全局,支持单组件内多字典同时使用 #37
  2. 存储管理增加图片路径提示和图片预览 #40
  3. 树形表格更换,采用 element-ui 自带的树形表格组件

修复

  1. 解决Gson找不到包的bug #141
  2. 解决ip2region.db路径不正确的问题 #146

2.3版本指南:https://docs.auauz.net/#/sjzn

预览地址:https://auauz.net/

项目源码

后端源码前端源码
Githubhttps://github.com/elunez/eladminhttps://github.com/elunez/eladmin-web
码云https://gitee.com/elunez/eladminhttps://gitee.com/elunez/eladmin-web
]]>