1 Star 0 Fork 131

yj2006062 / aicode

forked from 暖暖的阳光 / aicode 
加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
该仓库未声明开源许可证文件(LICENSE),使用请关注具体项目描述及其代码上游依赖。
克隆/下载
贡献代码
同步代码
取消
提示: 由于 Git 不支持空文件夾,创建文件夹后会生成空的 .keep 文件
Loading...
README

AI Code

技术交流 qq 群:839360512 项目支持docker启动方式,war启动方式,轻松快速上手, 项目已经经历了10多个项目,其中包含融资项目,模板几经修改和整合,很实用,新的功能按部就班添加中,期待大家的反馈和使用感受 一个基于freemarker为核心的代码生成框架,本项目目前支持sql进行反向生成java的代码,代码生成的程度取决于用的模板,目前整合的模板中 有如下:

- ssm+redis+swagger+lombok
- springboot-redis-swagger-lombok
- ssm+dubbo+redis+swagger+lombok
- ssh+redis+swagger+lombok
- spring-cloud-redis-lombok-sentry
- angular-template
- springboot-redis-swagger-lombok-frontend
- angular-template-i18n

模板分享地址: https://gitee.com/helixin/aicode_template sql脚本中板焊了模板,会在你构建项目时自动拉取到本地,构建代码完毕后将会删除,你可以开源你的模板到这个连接中,也可以自己建立私库自己用都可以,目的就是让重复的 代码写一次后用模板技术和抽象思维服务更多的项目

以上框架为基本常用的框架,目前只需要准备好你的sql脚本在此项目页上进行创建即可,然后aicode 会自动帮你把数据库创建出来用于反向生成代码使用, 自动从你的模板仓库中下载框架,当然也可以是用我们已经开发好的,代码会从dao->service->ctrl->frontend 一条龙生成,接口自动根据规则对接完 毕,也就是说你可以生成后直接运行你的项目代码,另外项目代码将会根据你的需要配置上git svn 地址后自动提交到对应的仓库中省去手工拷贝的麻烦,只 需要在开发工具中 git clone git://xxxxx.git即可,如果模板比较优秀可以节省代码50%左右无需再开发,比如包含了:增,删,查,改,分页,条 件查询,关联查询,关联分页查询等等,你需要关心的只是你的逻辑关系是否设置完整,模型关系是否设置完整用于生成时系统进行自动化,我们提供了web-ui管理界面,只需要登录账户即可 完成对代码的生成管理,你可以通过页面来完成模型关系的设置,以及对显示属性的设置,快速完成从数据库层到页面的定制化开发。

特点

ai-code 与其他开源的完整项目不同点在于技术整合框架的抽象,mvc的模型抽象,我们有这样的场景,有新的业务需求,用同样的技术框架,通常做法可能就是找一个项目然后删删改改提取 出来一个较为干净的框架,然后把新的业务模型,实体类,接口等等重新声明,创建在此基础上再做很多CRUD的编码,有时候我们很反感重复这些,但是又不得不做,通常做这些毫无意义又无聊 同意请举手,于是乎有没有办法做一个工具出来让新的业务模型设计好后拿到sql脚本 通过工具可以选择各种不同的技术框架组合,就像spring boot一样整合技术在一起,但是又 可以自动把mybatis mapper,dao/dto,service,ctrl,ui等等通用功能自动开发好呢?把常用的工具,加密算法等等通用的自动集成进去呢?比如swagger,gradle,maven等等 答案是肯定的ai-code就是这个思路,整合有给你定制的可能,业务随意变化,只要拿到sql脚本一切就是动动手指,点击生成,再也不用搞来搞去那些重复的不能再重复的无聊工作了。 这就是ai-code的基本思路和思想;

再来看下通常的开源思路是什么呢? 完整项目,比如RBAC模型下的管理系统,有权限,区域,部门,日志等等,这些无可厚非确实通用,但毕竟如果要和自己的项目融合是要调整的,而且编码习惯不同, 设计规则可能不满意,维护过慢等等问题,但是也是可以使用的,于是乎就有了各种 商城开源,权限管理开源,区域管理开源,可以关注学习没问题,非常棒,甚至直接用。

两种思路从不同的角度来看待重用问题,ai-code 只希望抛砖引玉,让抽象思维,整合思维,服务未来思维体现出来,期待更好地项目出现,基于ai-code,期待大家贡献 技术模板,让那个更多人从中受益,感谢大家的贡献。

模板引擎

目前支持一下模板引擎:

1.freemarker

2.beetl

使用方法

连接数据库:

-首先要做的就是建立ai_code的数据库(推荐数据库格式:编码为utf8mb4 排序为 utf8mb4_general_ci),建议使用mysql,脚本请用最新的版本日期,你可以在项目根目录下sql/aicodexxxxx.sql中找到合适的 sql脚本,比如创建数据库名为ai_code,数据库的ip为192.168.1.220,账户密码为username=root,password=xxxxx;

-找到项目下 AI/src/main/resources/jdbc.properties 文件将数据库链接修改成刚才初始化的数据库ip

jdbc.url=jdbc:mysql://192.168.1.220:3306/ai_code?useUnicode=true&characterEncoding=utf-8&zeroDateTimeBehavior=round&allowMultiQueries=true
jdbc.username=root
jdbc.password=xxxxx

修改完毕后可以直接启动,启动默认为8080端口 浏览器中打开输入:http://127.0.0.1:8080/index.html 默认账户:admin 888888尝试登录,你可以在数据库中修改次账户数据表明为account Image text

参考已有项目的效果 Image text

模板仓库添加

在你登陆后你可以添加自己的模板仓库

Image text

创建项目

有了模板之后可以创业见一个项目,然后按照下一步的指引操作下去即可完成操作 (此处为gif动画需要你登录账户才能看,osc的限制) image text

构建项目

构建很简单,点击即可自动完成对项目的生成,下载模板,生成代码,提交到git仓库,这个地方的日志输出是websocket,存储文档log可以反复查看 十分方便 (此处为gif动画需要你登录账户才能看,osc的限制) Image text

之后点击构建项目 按钮就开始进行想的自动构建了

启动项目

当你生成项目代码后你可以在你的git svn仓库中找到源码,也可以直接下载源码自行导入到开发工具中,然后运行,这里需要注意的是配置文件和 数据库的连接一定要修改,否则默认的将无法使用,一下为测试演示的界面图供参考 代码界面和运行启动项目 我用的是Idea 最好用的java开发工具,没有之一,开发用就用最好的工具,不将就 Image text

swagger界面如下,我只用了一个简单的表来演示,你的要有多复杂就有多复杂均可以实现 Image text

如果你体验了高效的代码生成和抽象思维把规律的重复的代码进行模板化后可以服务你未来更久的时间,那时候就体验到,编程除了用coding还可以用设计 来编码,所谓武功至高境界就是无招胜有招 就是这个意思,让代码服务你更久才有时间学习更多的技术和知识,让今天的一行代码在未来体现出更大价 值才是我们要思考和做的,期待大家的分享和模板的壮大,目前正在整理rabbitmq, kafka, rocketmq的分布式,微服务框架模板整合,后面将会 更好玩哦,模板链接再次推荐可以参考:https://gitee.com/helixin/aicode_template 祝你和你的团队编程愉快,coding让世界更美好。

docker 启动方式(推荐)

docker 依赖dockerhub 镜像(意思是你的网络要支持访问哦,大家明白哈,搞不定的加群),大家可以通过docker的常规命令pull run 即可,注意:docker镜像 中不包含数据库,数据库脚本请从项目中下载进行初始化,数据库名称请使用ai_code命名,以下docker命令操作 dockerhub 详细操作说明 https://hub.docker.com/r/hegaoye/aicode

直接使用下面的命令即可搞定,数据库与程序自动link在一起,方便简单

#检出数据库
docker pull hegaoye/mysql:1.0-beta
#启动数据库 设置 --hostname=aicode-db 用于link方式连接
docker run -p  3306:3306 -e MYSQL_ROOT_PASSWORD=aicode --hostname=aicode-db  --name aicode-db  --restart always -d hegaoye/mysql:1.0-beta  --lower_case_table_names=1

#搜索查看aicode的镜像是否存在
docker search aicode

#拉取aicode的镜像 hegaoye/aicode:1.0-beta
docker pull hegaoye/aicode:1.0-beta

#启动容器,注意 host,username,passowrd 要进行修改成自己的mysql主机 使用link 连接aicode-db
docker run --link aicode-db:aicode-db -e host=aicode-db:3306 -e username=root -e password=aicode -p 8080:8080 --name aicode --restart always -d  hegaoye/aicode:1.0-beta

#查看日志
docker logs --tail 1000 -f aicode

#重启,关闭,启动容器命令
docker restart|stop|start aicode

K8S 配置参考

###创建db####
apiVersion: apps/v1
kind: Deployment
metadata:
  name: mysql
spec:
  replicas: 1
  selector:
    matchLabels:
      app: mysql
  template:
    metadata:
      labels:
        app: mysql
    spec:
      containers:
        - name: mysql
          image: hegaoye/mysql:1.0-beta
          ports:
            - containerPort: 3306
          env:
            - name: MYSQL_ROOT_PASSWORD
              value: "888888" # 数据库的密码,修改为自己的
          args: ["--lower_case_table_names=1"]
      #注意 以下配置为发布在master主机上否则无法启动,如果有node节点可以删除此配置
      tolerations:
        - key: node-role.kubernetes.io/master
          operator: Exists
          effect: NoSchedule

---

apiVersion: v1
kind: Service
metadata:
  name: mysql
spec:
  ports:
    - port: 3306
      targetPort: 3306
      nodePort: 30306
  type: NodePort
  selector:
    app: mysql


###创建aicode####
apiVersion: apps/v1
kind: Deployment
metadata:
  name: aicode
  labels:
    app: aicode
spec:
  selector:
    matchLabels:
      app: aicode
  template:
    metadata:
      labels:
        app: aicode
    spec:
      containers:
        - name: aicode
          image: hegaoye/aicode:latest
          ports:
            - containerPort: 8080
          env:
            - name: host
              value: "mysql:3306" #对应db的service 名和开放的端口号 默认是3306
            - name: username
              value: "root"
            - name: password
              value: "888888"  # 数据库的密码 对应db中设置的
      #注意 以下配置为发布在master主机上否则无法启动,如果有node节点可以删除此配置
      tolerations:
        - key: node-role.kubernetes.io/master
          operator: Exists
          effect: NoSchedule


---

apiVersion: v1
kind: Service
metadata:
  name: aicode-svc
spec:
  ports:
    - port: 8001
      targetPort: 8080
      nodePort: 30880
  type: NodePort
  selector:
    app: aicode

编写模板说明:

模板语法采用freemarker编写,定义了一个实体类可以在项目io.aicode.base.core.TemplateData 下找到此类,大致的内置变量可以如下图

Image text

如果你需要编写自己的模板按照这里面的规则即可完成编写,如果需要参考已有模板请看顶部的连接分享你可以根据自己的需求修改一个出来然后也分享出来让大家 享受你的技术带来的便捷。

UML参考

uml信息可以自己打开vpp文件查看详细,仅仅放两张用于参考 Image text

Image text

模板长啥样?

模块化模板样貌 Image text

Ctrl模板类 Image text

mybatis sql 模板注意观察有关联关系哦 Image text

前端模板抽离样貌 Image text

项目技术点

  • spring mvc
  • mybatis
  • freemarker
  • websocket
  • java reflection
  • angular framework
  • git,svn client
  • jwt
  • gradle

注意

关于自己的sql脚本比如如下

/*==============================================================*/
/* Table: goods                                                 */
/*==============================================================*/
create table goods
(
   id                   bigint not null auto_increment,
   code                 varchar(64) not null comment '编码',
   name                 varchar(32) comment '商品名',
   stock                bigint comment '库存',
   status               varchar(32) comment '状态',
   primary key (id, code)
);

alter table goods comment '产品';

/*==============================================================*/
/* Table: "order"                                               */
/*==============================================================*/
create table "order"
(
   id                   bigint not null auto_increment,
   code                 varchar(64) not null comment '编码',
   order_no             varchar(32) not null comment '订单号',   
   primary key (id, code, order_no)
);

alter table "order" comment '订单';

这个sql在执行中失败,失败的原因在于 "order" 双引号不合法将无法执行,所以请检查后修改为order 的合法sql语句,最好在生成前执行验证sql 脚本的正确性,比如下面的

/*==============================================================*/
/* Table: order                                               */
/*==============================================================*/
create table `order`
(
   id                   bigint not null auto_increment,
   code                 varchar(64) not null comment '编码',
   order_no             varchar(32) not null comment '订单号',   
   primary key (id, code, order_no)
);

alter table `order` comment '订单';

去处后即可合法使用,一定要保障sql可以正常执行再用来跑代码,否则会失败

子项目

前端参考地址 https://gitee.com/helixin/ai-code-frontend

设计文档地址 https://gitee.com/helixin/AI-Code-Doc

模板仓库地址 https://gitee.com/helixin/aicode_template

docker教程 https://hub.docker.com/r/hegaoye/aicode

尝鲜演示地址

http://www.hegaoye.com admin 888888

空文件

简介

新一代代码生成器(新闻头条推荐),提供webUI管理方式,系统整合技术丰富如:spring cloud(全家桶),mybatis,mybatis-plus,mongodb,redis,ignite,caffine cache,hutool,kafka,rocketmq,rabbitmq,dubbo,nacos,euraka,sentry,log4j,swagger,swagger2 ,angularjs,vue,react,jquery 等前端技术,并在生成时自己作主,团队协作方便,代码支持增量生成,根据框架模块化管理,需要那些选择后自动生成;提供模板开发接口自由定义自己的模板,最终完成AI+模板=70%的代码量,细节请看readme介绍。根据需要可以选择性生成,支持docker 启动... 展开 收起
Java
取消

发行版

暂无发行版

贡献者

全部

近期动态

加载更多
不能加载更多了
Java
1
https://gitee.com/yj2006062/aicode.git
git@gitee.com:yj2006062/aicode.git
yj2006062
aicode
aicode
dev

搜索帮助

14c37bed 8189591 565d56ea 8189591