# open-cloud **Repository Path**: dingjunjun_codeSpace/open-cloud ## Basic Information - **Project Name**: open-cloud - **Description**: 基于springcloud、oauth2、nacos打造的微服务开放平台. 利于企业分布式开发,集中管理微服务接口,SpringSecurity深度拓展,为微服务接口资源保驾护航。 - **Primary Language**: Java - **License**: MIT - **Default Branch**: 2.0.0 - **Homepage**: None - **GVP Project**: No ## Statistics - **Stars**: 0 - **Forks**: 779 - **Created**: 2022-10-14 - **Last Updated**: 2022-10-14 ## Categories & Tags **Categories**: Uncategorized **Tags**: None ## README
## 微服务开放平台 2.0.0 更快、更新、更全面 #### 开源不易,请随手给个Star! 感谢支持! #### 简介 搭建基于OAuth2的开放平台、为APP端、应用服务提供统一接口管控平台、为第三方合作伙伴的业务对接提供授信可控的技术对接平台 + 分布式架构,统一配置中心,服务治理.fegin(RPC)内部调用,微服务管理开发更便捷! + 统一API网关、访问鉴权、接口管理、参数验签、接口调用更安全! + 深度整合SpringSecurity+Oauth2,统一认证协议、url级鉴权、更细粒度、灵活的ABAC权限控制! + 前后端分离方式开发应用,分工合作更高效! + 代码合理封装、简单易懂、简化开发流程! 开发平台门户预览 运营管理后台预览 + 后台默认账号:admin 123456 + 后台测试账号:test 123456 #### 更新日志 v-2.1.0 2019-05-26 (重大变更) 1. 重新梳理base表结构和权限相关接口,解决用户和客户端动态分配权。 机制问题暂不支持用户动态分配角色,需重新登录获取最新角色 2. 优化页面功能 3. 升级nacos客户端版本.支持1.0.0以上版本 5. 完善权限数据,去除外键约束. 6. 升级方式更新ui和服务代码, 重新执行base.sql。手动删除无效表 7. 移除app-admin模块 相关功能迁移到opencloud-auth-provider中 v-2.0.0 2019-05-01 1. 升级SpringCloud Greenwich.SR1,SpringBoot 2.1.4.RELEASE 2. 重构项目结构 3. 优化Zuul网关性能 4. 增加官方SpringCloudGateway 5. 迁移Gateway功能到base服务中 6. 增加MybatisPlus 7. 使用.yml代替.properties v-1.0.0 2019-03-18 1. 重构项目结构 2. 重构表结构 3. 重构授权逻辑 4. 提取公共配置,并迁移到Nacos配置中心 5. 优化功能 #### 系统结构图  #### 功能介绍  #### 服务端源码 码云 github #### vue后台UI源码 后台UI源码 #### vue门户UI源码 门户UI源码 #### 代码生成器 代码生成器 #### 使用手册 使用手册 #### 学习交流群 交流群:760809808 扫码进群:  #### 代码结构 ``` lua open-cloud ├── docs ├── bin -- 执行脚本 ├── config -- 公共配置,用于导入到nacos配置中心 ├── generator -- mapper生成器 ├── sql -- sql文件 ├── opencloud-app -- 应用服务模块 ├── app-opensite-provider -- 门户网站开发者认证中心和资源服务器(port = 7211) ├── opencloud-common -- 公共类和jar包依赖 ├── opencloud-common-core -- 提供微服务相关依赖包、工具类、全局异常解析等... ├── opencloud-common-starter -- SpringBoot自动扫描 ├── opencloud-gateway -- 开放API服务模块 ├── opencloud-api-gateway -- API开放网关-基于SpringCloudGateway-(port = 8888) ├── opencloud-api-gateway-zuul --(较为稳定推荐使用)API开放网关-基于Zuul-(port = 8888) ├── opencloud-api-sdk -- 对API服务第三方调用集成Jar包的封装(待完善) ├── opencloud-platform -- 平台服务模块 ├── opencloud-base-client -- 平台基础服务接口 ├── opencloud-base-provider -- 平台基础服务(port = 8233) ├── opencloud-auth-client -- 平台认证服务接口 ├── opencloud-auth-provider -- 平台认证服务(port = 8211) ├── opencloud-msg-client -- 平台消息服务接口 ├── opencloud-msg-provider -- 平台消息服务(port = 8266) ├── opencloud-scheduler-client -- 平台任务调度接口 ├── opencloud-scheduler-provider -- 平台任务调度服务(port = 8501) ├── opencloud-bpm-client -- 平台工作流接口 ├── opencloud-bpm-provider -- 平台工作流服务(port = 8255) ``` #### 快速开始 上手难度:★★★★ 本项目基于springCloud打造的分布式快速开发框架. 需要了解SpringCloud,SpringBoot开发,分布式原理。 1. 准备环境 + Java1.8 + 阿里巴巴Nacos服务发现和注册中心 nacos.io + Redis + RabbitMq (需安装rabbitmq_delayed_message_exchange插件 下载地址) + Mysql + Maven + Nodejs 2. 执行创建数据库open-platform并执行sql脚本 + docs/sql/oauth2.sql + docs/sql/base.sql + docs/sql/gateway.sql + docs/sql/quartz.sql && scheduler.sql 3. 启动nacos服务发现&配置中心,新建公共配置文件 + 访问 http://localhost:8848/nacos/index.html + 新建配置文件 ``` + 项目目录/docs/config/db.properties > db.properties + 项目目录/docs/config/rabbitmq.properties > rabbitmq.properties + 项目目录/docs/config/redis.properties > redis.properties + 项目目录/docs/config/common.properties > common.properties 如图:  4. 修改主pom.xml 初始化maven项目 ``` bush maven clean install ``` 本地启动,默认不用修改 ``` xml