时隔2个多月的研发,11月25日,终于把Idea插件BG-BOOM的1.1.0版本搞上线了,本次更新勇哥也是百忙之中挤时间,加班加点开发为粉丝,目的也主要是帮助大家提升开发效率,有更多摸鱼和内卷时间;好了,切回正题,本次带来更新的功能有点diao,希望大家喜欢并点赞:
提高创建SpringBoot项目的效率
一键生成启动类、配置文件
自动导入springboot、springcloud、springcloudalibaba等起步依赖
提高启动、找启动类、找配置文件的效率
一键启、停全部微服务
一键定位启动类
提高大家对数据库表直观理解
提供了ER图,自动匹配逻辑主键
提高JPA开发的效率
一键拷贝JPA的controller、service、pojo、dao等代码
提高Mariadb的使用
直接在代码中,不用配置连接,一键打开Mariadb查询客户端
一般在工作中,大多程序时通过Maven Archetype 来创建新项目和模块,这种基于骨架方式来创建项目有一些弊端:
骨架的资源需要通过网络下载,如果网络抖动下载丢失资源了,整个项目就崩溃了
骨架的资源需要通过网络下载,如果网速慢,则创建过程可能需要1~2分钟
骨架中默认包括的文件与实践开发的项目不符合,往往创建完成项目后,需要程序员手动删除
你是不是也是这样创建项目的呢?
勇哥在插件中特制了一个项目创建的引导功能:
创建时输入启动类的名称、勾选默认导入的springboot-starter,项目创建的时候就会自动创建启动类,导入勾选的starter;这样创建的项目:
自动创建启动类;
自动在pom.xml中导入spring-boot的那些依赖;
自动创建application.yml配置文件,并设置基础属性
创建的工程也是maven项目,但是项目不是基于骨架创建,因此不走网络下载资源,因此创建效率自然高效,稳定。
秀一波:
idea的项目启动如果是单体项目,是没什么问题的,但是如果是微服务或者模块较多的情况下,就会存在以下问题:
第一次启动,需要一层一层的点击到启动类,让右键启动;如果启动的项目多、项目层级多,那么这是非常繁琐的
第N次启动,可以从快速启动下拉中、Services中启动,但是下拉选择和Services都是多层次设计,启动项目都要点击2次以上,对一项目多了,还是麻烦
勇哥在插件中特制了一个快速启动栏:
自动扫描当前项目中的微服务(仅支持SpringBoot工程)
扫描到的微服务,自动显示到快速启动栏中
从快速启动栏中,你可以一键操作:
启动某个项目
停止某个项目
启动所有项目
停止所有项目
点击在浏览器中打开项目
定位启动类
如果快速启动栏中项目太多,也不需要担心,可以左右拖动,:)NICE
现在在工作中,基本上表与表之间都不会使用外键约束,而是使用逻辑外键,这样的话,在Navicat这些常规数据库中ER模型中是不会画出表与表之间的关系,阻碍了大家对于表关系的快速掌握。因此勇哥自行开发了一套基于逻辑外键的ER图模型:
自动识别表中的逻辑外键(一般是以_id结尾的字段)
可以动态显示/关闭逻辑外键关联线
可以ER图保存为图片
可以自有拖动位置、拖动调整大小
勇哥为此还写了横、竖两个刻度尺,帅不帅,刻度尺源码如下:给勇哥点个赞吧~~~,勇哥也需要你们的精神粮食
- package com.madou.dbtool.uml.cantainer;
-
- import javax.swing.*;
- import java.awt.*;
-
- /**
- * 刻度尺面板类
- */
- public class RuleContainer extends JPanel implements ScaleFunction {
-
- // 背景颜色
- Color backgroudColor = Color.BLACK;
- // 刻度颜色
- Color fontColor = Color.WHITE;
- // 是否垂直
- boolean isVertical = false;
- // 左边距
- int left = 0;
- // 缩放比例,每走一格+-5
- int scale = 100;
-
- public RuleContainer() {
- this(false,0);
- }
-
- public RuleContainer(int left) {
- this(false,left);
- }
-
- public RuleContainer(boolean isVertical, int left){
- this.setLayout(null);
- this.setBackground(Color.RED);
- this.setCursor(new Cursor(Cursor.CROSSHAIR_CURSOR));
- this.left = left;
- this.isVertical = isVertical;
- if(this.isVertical){
- this.setPreferredSize(new Dimension(20, -1));
- }else {
- this.setPreferredSize(new Dimension(-1, 20));
- }
- }
-
- public void drawX(Graphics graphics){
- int width = this.getWidth();
- int height = this.getHeight();
- int index = 0;
- int count = 0;
- double postion = left;
- int screenResolution = Toolkit.getDefaultToolkit().getScreenResolution();
- int step = (int) Math.round((screenResolution/25.4)/(scale/100F));
- Font font = Font.getFont("微软雅黑");
- graphics.setColor(fontColor);
- graphics.setFont(font);
- if(isVertical){
- if(scale<101) {
- height = (int) (height/(scale/100F));
- }
- while (postion
- if(count%10==0){
- graphics.drawLine(width/2,(int) postion,width,(int) postion);
- graphics.drawString(""+index++, 0,(int) postion-1);
- }else{
- if(count>0&&count%5==0){
- graphics.drawLine(width * 3 / 5, (int) postion, width, (int) postion);
- }else {
- graphics.drawLine(width * 4 / 5, (int) postion, width, (int) postion);
- }
- }
- postion+=step;
- count++;
- }
- }else{
- if(scale<101) {
- width = (int) (width / (scale / 100F));
- }
- while (postion
- if(count%10==0){
- graphics.drawLine((int) postion,height/2,(int) postion,height);
- graphics.drawString(""+index++, (int) postion-3,height/2);
- }else{
- if(count>0&&count%5==0){
- graphics.drawLine((int) postion,height*3/5,(int) postion,height);
- }else {
- graphics.drawLine((int) postion,height*4/5,(int) postion,height);
- }
- }
- postion+=step;
- count++;
- }
- }
-
- }
-
- @Override
- protected void paintComponent(Graphics graphics) {
- graphics.setColor(backgroudColor);
- graphics.fillRect(0,0,getWidth(),getHeight());
- drawX(graphics);
- }
-
- public static void main(String[] args) {
- JFrame jFrame = new JFrame("刻度尺");
- jFrame.setLayout(new BorderLayout());
- jFrame.setPreferredSize(new Dimension(600,600));
- RuleContainer scalePanel = new RuleContainer(false,30);
- jFrame.add(scalePanel,BorderLayout.NORTH);
- scalePanel = new RuleContainer(true,0);
- jFrame.add(scalePanel,BorderLayout.WEST);
- jFrame.setVisible(true);
- jFrame.pack();
- }
-
- @Override
- public void scale(int step) {
- scale+=step;
- if(scale<20){
- scale=20;
- }
- if(scale>500){
- scale=500;
- }
- applyZoom();
- }
-
- private void applyZoom() {
- setPreferredSize(new Dimension((int) (scale/100F * getWidth()), (int) (scale/100F * getHeight())));
- validate();
- repaint();
- }
-
- @Override
- public void reset() {
- scale=100;
- scale(0);
- }
- }
在Bg-Ber中一键拷贝JPA代码
勇哥在插件增加了数据库客户端,在数据库客户端中新增了SQL逆向生成JPA代码的功能:
-
生成Controller
-
生成Service
-
生成ServiceImpl
-
生成Dao
-
生成Pojo
代码自动生成演示:
在Bg-Boom中使用Mariadb客户端
Mariadb客户端依旧继承Mysql客户端的牛逼设计:
-
自动识别代码中的POJO类,并增加打开查询客户端的功能菜单和按钮
-
在查询客户端中自动生成JPA、Mybatis-plus相关代码
-
.........等等,此处省略N个功能描述
-
相关阅读:
spring boot 下载resources下的静态文件为流格式
Observability:使用 Elastic Observability 摄取和分析 Prometheus 指标
网络协议--IP选路
设计一个实用好看的餐边柜或者酒柜需要知道这5点。福州中宅装饰,福州装修
Spring Security 在登录时如何添加图形验证码
详解 Flink 的容错机制
微信收款码费率0.38太坑了
欧拉函数和线性筛法:AcWing 874. 筛法求欧拉函数
使用easyexcel模板导出的两个坑(Map空数据列错乱和不支持嵌套对象)
工业互联网安全概述
-
原文地址:https://blog.csdn.net/luoxueyong/article/details/128175416