Home

Awesome

<h1 align="center"><a href="https://github.com/xkcoding" target="_blank">Spring Boot Demo</a></h1> <p align="center"> <a href="https://travis-ci.com/xkcoding/spring-boot-demo"><img alt="Travis-CI" src="https://travis-ci.com/xkcoding/spring-boot-demo.svg?branch=master"/></a> <a href="https://www.codacy.com/app/xkcoding/spring-boot-demo?utm_source=github.com&amp;utm_medium=referral&amp;utm_content=xkcoding/spring-boot-demo&amp;utm_campaign=Badge_Grade"><img alt="Codacy" src="https://api.codacy.com/project/badge/Grade/1f2e3d437b174bfc943dae1600332ec1"/></a> <a href="https://xkcoding.com"><img alt="author" src="https://img.shields.io/badge/author-Yangkai.Shen-blue.svg"/></a> <a href="https://www.oracle.com/technetwork/java/javase/downloads/index.html"><img alt="JDK" src="https://img.shields.io/badge/JDK-1.8.0_162-orange.svg"/></a> <a href="https://docs.spring.io/spring-boot/docs/2.1.0.RELEASE/reference/html/"><img alt="Spring Boot" src="https://img.shields.io/badge/Spring Boot-2.1.0.RELEASE-brightgreen.svg"/></a> <a href="https://github.com/xkcoding/spring-boot-demo/blob/master/LICENSE"><img alt="LICENSE" src="https://img.shields.io/github/license/xkcoding/spring-boot-demo.svg"/></a> </p> <p align="center"> <a href="https://github.com/xkcoding/spring-boot-demo/stargazers"><img alt="star" src="https://img.shields.io/github/stars/xkcoding/spring-boot-demo.svg?label=Stars&style=social"/></a> <a href="https://github.com/xkcoding/spring-boot-demo/network/members"><img alt="star" src="https://img.shields.io/github/forks/xkcoding/spring-boot-demo.svg?label=Fork&style=social"/></a> <a href="https://github.com/xkcoding/spring-boot-demo/watchers"><img alt="star" src="https://img.shields.io/github/watchers/xkcoding/spring-boot-demo.svg?label=Watch&style=social"/></a> </p> <p align="center"> <span>中文 | <a href="./README.en.md">English</a></span> </p>

项目简介

spring boot demo 是一个用来深度学习并实战 spring boot 的项目,目前总共包含 66 个集成demo,已经完成 55 个。

该项目已成功集成 actuator(监控)、admin(可视化监控)、logback(日志)、aopLog(通过AOP记录web请求日志)、统一异常处理(json级别和页面级别)、freemarker(模板引擎)、thymeleaf(模板引擎)、Beetl(模板引擎)、Enjoy(模板引擎)、JdbcTemplate(通用JDBC操作数据库)、JPA(强大的ORM框架)、mybatis(强大的ORM框架)、通用Mapper(快速操作Mybatis)、PageHelper(通用的Mybatis分页插件)、mybatis-plus(快速操作Mybatis)、BeetlSQL(强大的ORM框架)、upload(本地文件上传和七牛云文件上传)、redis(缓存)、ehcache(缓存)、email(发送各种类型邮件)、task(基础定时任务)、quartz(动态管理定时任务)、xxl-job(分布式定时任务)、swagger(API接口管理测试)、security(基于RBAC的动态权限认证)、SpringSession(Session共享)、Zookeeper(结合AOP实现分布式锁)、RabbitMQ(消息队列)、Kafka(消息队列)、websocket(服务端推送监控服务器运行信息)、socket.io(聊天室)、ureport2(中国式报表)、打包成war文件、集成 ElasticSearch(基本操作和高级查询)、Async(异步任务)、集成Dubbo(采用官方的starter)、MongoDB(文档数据库)、neo4j(图数据库)、docker(容器化)、JPA多数据源Mybatis多数据源代码生成器、GrayLog(日志收集)、JustAuth(第三方登录)、LDAP(增删改查)、动态添加/切换数据源、单机限流(AOP + Guava RateLimiter)、分布式限流(AOP + Redis + Lua)、ElasticSearch 7.x(使用官方 Rest High Level Client)、HTTPS、Flyway(数据库初始化)、UReport2(中国式复杂报表)。

如果大家还有想要集成的demo,也可在 issue 里提需求。我会额外添加在 TODO 列表里。✊

分支介绍

开发环境

运行方式

提示:如果是 fork 的朋友,同步代码的请参考:https://xkcoding.com/2018/09/18/how-to-update-the-fork-project.html

  1. git clone https://github.com/xkcoding/spring-boot-demo.git
  2. 使用 IDEA 打开 clone 下来的项目
  3. 在 IDEA 中 Maven Projects 的面板导入项目根目录下 的 pom.xml 文件
  4. Maven Projects 找不到的童鞋,可以勾上 IDEA 顶部工具栏的 View -> Tool Buttons ,然后 Maven Projects 的面板就会出现在 IDEA 的右侧
  5. 找到各个 Module 的 Application 类就可以运行各个 demo 了
  6. 注意:每个 demo 均有详细的 README 配套,食用 demo 前记得先看看哦~
  7. 注意:运行各个 demo 之前,有些是需要事先初始化数据库数据的,亲们别忘记了哦~

项目趋势

Stargazers over time

其他

团队纳新

组内招人啦,HC 巨多,Base 杭州,感兴趣的小伙伴,查看 岗位详情

开源推荐

11628591293_.pic_hd

开发计划

查看 TODO 文件

各 Module 介绍

Module 名称Module 介绍
demo-helloworldspring-boot 的一个 helloworld
demo-propertiesspring-boot 读取配置文件中的内容
demo-actuatorspring-boot 集成 spring-boot-starter-actuator 用于监控 spring-boot 的启动和运行状态
demo-admin-clientspring-boot 集成 spring-boot-admin 来可视化的监控 spring-boot 程序的运行状态,可以与 actuator 互相搭配使用,客户端示例
demo-admin-serverspring-boot 集成 spring-boot-admin 来可视化的监控 spring-boot 程序的运行状态,可以与 actuator 互相搭配使用,服务端示例
demo-logbackspring-boot 集成 logback 日志
demo-log-aopspring-boot 使用 AOP 切面的方式记录 web 请求日志
demo-exception-handlerspring-boot 统一异常处理,包括2种,第一种返回统一的 json 格式,第二种统一跳转到异常页面
demo-template-freemarkerspring-boot 集成 Freemarker 模板引擎
demo-template-thymeleafspring-boot 集成 Thymeleaf 模板引擎
demo-template-beetlspring-boot 集成 Beetl 模板引擎
demo-template-enjoyspring-boot 集成 Enjoy 模板引擎
demo-orm-jdbctemplatespring-boot 集成 Jdbc Template 操作数据库,并简易封装通用 Dao 层
demo-orm-jpaspring-boot 集成 spring-boot-starter-data-jpa 操作数据库
demo-orm-mybatisspring-boot 集成原生mybatis,使用 mybatis-spring-boot-starter 集成
demo-orm-mybatis-mapper-pagespring-boot 集成通用MapperPageHelper,使用 mapper-spring-boot-starterpagehelper-spring-boot-starter 集成
demo-orm-mybatis-plusspring-boot 集成 mybatis-plus,使用 mybatis-plus-boot-starter 集成,集成 BaseMapper、BaseService、ActiveRecord 操作数据库
demo-orm-beetlsqlspring-boot 集成 beetl-sql,使用 beetl-framework-starter 集成
demo-uploadspring-boot 文件上传示例,包含本地文件上传以及七牛云文件上传
demo-cache-redisspring-boot 整合 redis,操作redis中的数据,并使用redis缓存数据
demo-cache-ehcachespring-boot 整合 ehcache,使用 ehcache 缓存数据
demo-emailspring-boot 整合 email,包括发送简单文本邮件、HTML邮件(包括模板HTML邮件)、附件邮件、静态资源邮件
demo-taskspring-boot 快速实现定时任务
demo-task-quartzspring-boot 整合 quartz,并实现对定时任务的管理,包括新增定时任务,删除定时任务,暂停定时任务,恢复定时任务,修改定时任务启动时间,以及定时任务列表查询,提供前端页面
demo-task-xxl-jobspring-boot 整合xxl-job,并提供绕过 xxl-job-admin 对定时任务的管理的方法,包括定时任务列表,触发器列表,新增定时任务,删除定时任务,停止定时任务,启动定时任务,修改定时任务,手动触发定时任务
demo-swaggerspring-boot 集成原生的 swagger 用于统一管理、测试 API 接口
demo-swagger-beautyspring-boot 集成第三方 swagger swagger-bootstrap-ui 美化API文档样式,用于统一管理、测试 API 接口
demo-rbac-securityspring-boot 集成 spring security 完成基于RBAC权限模型的权限管理,支持自定义过滤请求,动态权限认证,使用 JWT 安全认证,支持在线人数统计,手动踢出用户等操作
demo-rbac-shirospring-boot 集成 shiro 实现权限管理<br /> <span style="color:pink;">待完成</span>
demo-sessionspring-boot 集成 Spring Session 实现Session共享、重启程序Session不失效
demo-oauthspring-boot 实现 oauth 服务器功能,实现授权码机制<br /> <span style="color:pink;">待完成</span>
demo-socialspring-boot 集成第三方登录,集成 justauth-spring-boot-starter 实现QQ登录、GitHub登录、微信登录、谷歌登录、微软登录、小米登录、企业微信登录。
demo-zookeeperspring-boot 集成 Zookeeper 结合AOP实现分布式锁
demo-mq-rabbitmqspring-boot 集成 RabbitMQ 实现基于直接队列模式、分列模式、主题模式、延迟队列的消息发送和接收
demo-mq-rocketmqspring-boot 集成 RocketMQ,实现消息的发送和接收<br /> <span style="color:pink;">待完成</span>
demo-mq-kafkaspring-boot 集成 kafka,实现消息的发送和接收
demo-websocketspring-boot 集成 websocket,后端主动推送前端服务器运行信息
demo-websocket-socketiospring-boot 使用 netty-socketio 集成 websocket,实现一个简单的聊天室
demo-ureport2spring-boot 集成 ureport2 实现复杂的自定义的中国式报表<br /> <span style="color:pink;">待完成</span>
demo-uflospring-boot 集成 uflo 快速实现轻量级流程引擎<br /> <span style="color:pink;">待完成</span>
demo-urulespring-boot 集成 urule 快速实现规则引擎<br /> <span style="color:pink;">待完成</span>
demo-activitispring-boot 集成 activiti 7 流程引擎<br /> <span style="color:pink;">待完成</span>
demo-asyncspring-boot 使用原生提供的异步任务支持,实现异步执行任务
demo-warspring-boot 打成 war 包的配置
demo-elasticsearchspring-boot 集成 ElasticSearch,集成 spring-boot-starter-data-elasticsearch 完成对 ElasticSearch 的高级使用技巧,包括创建索引、配置映射、删除索引、增删改查基本操作、复杂查询、高级查询、聚合查询等
demo-dubbospring-boot 集成 Dubbo,分别为公共模块 spring-boot-demo-dubbo-common、服务提供方spring-boot-demo-dubbo-provider、服务调用方spring-boot-demo-dubbo-consumer
demo-mongodbspring-boot 集成 MongoDB,使用官方的 starter 实现增删改查
demo-neo4jspring-boot 集成 Neo4j 图数据库,实现一个校园人物关系网的demo
demo-dockerspring-boot 容器化
demo-multi-datasource-jpaspring-boot 使用JPA集成多数据源
demo-multi-datasource-mybatisspring-boot 使用Mybatis集成多数据源,使用 Mybatis-Plus 提供的开源解决方案实现
demo-sharding-jdbcspring-boot 使用 sharding-jdbc 实现分库分表,同时ORM采用 Mybatis-Plus
demo-tiospring-boot 集成 tio 网络编程框架<br /> <span style="color:pink;">待完成</span>
demo-grpcspring-boot 集成grpc,配置tls/ssl,参见ISSUE#5<br /> <span style="color:pink;">待完成</span>
demo-codegenspring-boot 集成 velocity 模板技术实现的代码生成器,简化开发
demo-graylogspring-boot 集成 graylog 实现日志统一收集
demo-ssospring-boot 集成 SSO 单点登录,参见 ISSUE#12<br /> <span style="color:pink;">待完成</span>
demo-ldapspring-boot 集成 LDAP,集成 spring-boot-starter-data-ldap 完成对 Ldap 的基本 CURD操作, 并给出以登录为实战的 API 示例,参见 ISSUE#23,感谢 @fxbin
demo-dynamic-datasourcespring-boot 动态添加数据源、动态切换数据源
demo-ratelimit-guavaspring-boot 使用 Guava RateLimiter 实现单机版限流,保护 API
demo-ratelimit-redisspring-boot 使用 Redis + Lua 脚本实现分布式限流,保护 API
demo-httpsspring-boot 集成 HTTPS
demo-elasticsearch-rest-high-level-clientspring boot 集成 ElasticSearch 7.x 版本,使用官方 Rest High Level Client 操作 ES 数据
demo-flywayspring boot 集成 Flyway,项目启动时初始化数据库表结构,同时支持数据库脚本版本控制
demo-ureport2spring boot 集成 Ureport2,实现中国式复杂报表设计

特别感谢

License

MIT

Copyright (c) 2018 Yangkai.Shen