Git Product home page Git Product logo

chillzhuang / blade-tool Goto Github PK

View Code? Open in Web Editor NEW
1.6K 72.0 773.0 6.32 MB

SpringBlade 3.0 架构核心工具包,SpringBlade 是一个由商业级项目升级优化而来的SpringCloud分布式微服务架构、SpringBoot单体式微服务架构并存的综合型项目,采用Java8 API重构了业务代码,完全遵循阿里巴巴编码规范。采用Spring Boot 2 、Spring Cloud 2020 、Mybatis 等核心技术,同时提供基于React和Vue的两个前端框架用于快速搭建企业级的SaaS多租户微服务平台。 官网:https://bladex.vip

License: GNU Lesser General Public License v3.0

Java 100.00%

blade-tool's Introduction

Build Status Build Status Coverage Status Downloads

SpringBlade微服务开发平台

  • 采用前后端分离的模式,前端开源两个框架:Sword (基于 React、Ant Design)、Saber (基于 Vue、Element-UI)
  • 后端采用SpringCloud全家桶,并同时对其基础组件做了高度的封装,单独开源出一个框架:BladeTool
  • BladeTool已推送至Maven**库,直接引入即可,减少了工程的臃肿,也可更注重于业务开发
  • 集成Sentinel从流量控制、熔断降级、系统负载等多个维度保护服务的稳定性。
  • 注册中心、配置中心选型Nacos,为工程瘦身的同时加强各模块之间的联动。
  • 使用Traefik进行反向代理,监听后台变化自动化应用新的配置文件。
  • 极简封装了多租户底层,用更少的代码换来拓展性更强的SaaS多租户系统。
  • 借鉴OAuth2,实现了多终端认证系统,可控制子系统的token权限互相隔离。
  • 借鉴Security,封装了Secure模块,采用JWT做Token认证,可拓展集成Redis等细颗粒度控制方案。
  • 稳定生产了一年,经历了从 Camden -> Hoxton -> 2021 的技术架构,也经历了从fat jar -> docker -> k8s + jenkins的部署架构
  • 项目分包明确,规范微服务的开发模式,使包与包之间的分工清晰。

架构图

工程结构

blade-tool
├── blade-core-boot -- 业务包综合模块
├── blade-core-cloud -- cloud封装模块
├── blade-core-datascope -- 数据权限封装模块
├── blade-core-develop -- 代码生成封装模块
├── blade-core-launch -- 基础启动模块
├── blade-core-loadbalancer -- 灰度服务封装模块
├── blade-core-log -- 日志封装模块 
├── blade-core-mybatis -- mybatis拓展封装模块 
├── blade-core-oss -- 对象存储封装模块 
├── blade-core-report -- 报表封装模块 
├── blade-core-secure -- 安全封装模块 
├── blade-core-social -- 第三方登录封装模块 
├── blade-core-swagger -- swagger拓展封装模块 
├── blade-core-test -- 单元测试封装模块 
├── blade-core-tool -- 单元测试封装模块 
└── blade-core-transaction -- 分布式事物封装模块 

官方信息

  • 官网地址:https://bladex.vip
  • 问答社区:https://sns.bladex.vip
  • 会员计划:SpringBlade会员计划
  • 交流一群:477853168(满)
  • 交流二群:751253339(满)
  • 交流三群:784729540(满)
  • 交流四群:1034621754(满)
  • 交流五群:946350912(满)
  • 交流六群:511624269(满)
  • 交流七群:298061704

在线演示

数据大屏

技术文档

项目地址

开源协议

LGPL(GNU Lesser General Public License

LGPL是GPL的一个为主要为类库使用设计的开源协议。和GPL要求任何使用/修改/衍生之GPL类库的的软件必须采用GPL协议不同。LGPL允许商业软件通过类库引用(link)方式使用LGPL类库而不需要开源商业软件的代码。这使得采用LGPL协议的开源代码可以被商业软件作为类库引用并发布和销售。

但是如果修改LGPL协议的代码或者衍生,则所有修改的代码,涉及修改部分的额外代码和衍生的代码都必须采用LGPL协议。因此LGPL协议的开源代码很适合作为第三方类库被商业软件引用,但不适合希望以LGPL协议代码为基础,通过修改和衍生的方式做二次开发的商业软件采用。

用户权益

  • 允许以引入不改源码的形式免费用于学习、毕设、公司项目、私活等。
  • 特殊情况修改代码,但仍然想闭源需经过作者同意。
  • 对未经过授权和不遵循 LGPL 协议二次开源或者商业化我们将追究到底。
  • 参考请注明:参考自 mica:https://github.com/lets-mica/mica ,blade-tool:https://github.com/chillzhuang/blade-tool 。另请遵循 LGPL 协议。
  • 注意:若禁止条款被发现有权追讨 19999 的授权费。

界面

BladeX 工作流一览

Sword 界面一览

Saber 界面一览

监控界面一览

鸣谢

blade-tool's People

Contributors

chillzhuang avatar chunmenglu avatar dependabot[bot] avatar lohasle avatar

Stargazers

 avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar

Watchers

 avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar

blade-tool's Issues

优化ForestNodeManager

`public class ForestNodeManager {

/**
 * 森林的所有节点
 */
private ImmutableMap<Long, T> nodeMap ;

/**
 * 森林的父节点ID
 */
private Map<Long,Object> parentIdMap = Maps.newHashMap() ;

public ForestNodeManager(List<T> nodes) {
	nodeMap = Maps.uniqueIndex(nodes, INode::getId) ;
}

/**
 * 根据节点ID获取一个节点
 *
 * @param id 节点ID
 * @return 对应的节点对象
 */
public INode getTreeNodeAT(Long id) {
	if(nodeMap.containsKey(id)) {
		return nodeMap.get(id) ;
	}
	return null;
}

/**
 * 增加父节点ID
 *
 * @param parentId 父节点ID
 */
public void addParentId(Long parentId) {
	parentIdMap.put(parentId,"");
}

/**
 * 获取树的根节点(一个森林对应多颗树)
 *
 * @return 树的根节点集合
 */
public List<T> getRoot() {
	List<T> roots = new ArrayList<>();
	nodeMap.entrySet().forEach(forestNode -> {
		T node = forestNode.getValue();
		if (node.getParentId() == 0 || parentIdMap.containsKey(node.getId())) {
			roots.add(node);
		}
	});
	return roots;
}

}`

学习源码同时使用到这个配合avue使用的树组件,把List遍历修改成了Hash匹配
使用到guava
应对菜单较多的情况应该会有提升

修改一些功能

您好,
我可以使用改开源库进行 个人学习开发一些项目吗?
其中可能会修改到源代码

JDK11出现包错误:NoClassDefFoundError: javax/xml/bind/DatatypeConverter

环境

JDK11

问题描述

org.springblade.core.secure.utils.SecureUtil中使用的Base64处理工具包javax.xml.bind.DatatypeConverter无法使用,报如下错误:
java.lang.NoClassDefFoundError: javax/xml/bind/DatatypeConverter
at org.springblade.core.secure.utils.SecureUtil.(SecureUtil.java:51)

说明

使用JDK8重新编译运行正常

关于jwt token 的签名key在代码中暴露且无法注入修改的问题

在代码文件

/blade-core-launch/src/main/java/org/springblade/core/launch/constant/TokenConstant.java

内,有定义变量

String SIGN_KEY = "Blade";

该变量的值在

/blade-core-secure/src/main/java/org/springblade/core/secure/utils/SecureUtil.java

中作为 jwt token的加解密的签名key进行使用。

从而导致引用本项目作为类库使用时,token生成时用的签名key必须是"Blade",由blade-core-secure拦截鉴权时,自动根据签名key值"Blade"进行token解密。

本项目遵从 LGPL 协议,从而引用本项目作为类库使用时,不能修改(源码)签名key,以至于人人都可以对jwt token进行解密了。。。

这个问题如何解决?使用时通过获取作者授权然后修改源码?或者是参与付费进行二次开发?

JWT无法设置过长失效时间

blade-core-secure/src/main/java/org/springblade/core/secure/utils/SecureUtil.java中
accessTokenValidity或refreshTokenValidity设置值过大会存在溢出情况

//添加Token过期时间
long expireMillis;
if (tokenType.equals(TokenConstant.ACCESS_TOKEN)) {
	expireMillis = clientDetails.getAccessTokenValidity() * 1000;
} else if (tokenType.equals(TokenConstant.REFRESH_TOKEN)) {
	expireMillis = clientDetails.getRefreshTokenValidity() * 1000;
} else {
	expireMillis = getExpire();
}

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. 📊📈🎉

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❤️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.