若依(RuoYi)权限管理系统入门-搭建
ztj100 2025-01-13 19:19 17 浏览 0 评论
最近单位在搭建统一权限管理的系统,在网上看到了若依的开源系统,若依管理系统基于Spring boot搭建的权限管理系统.
一、基本介绍
1.1 架构图
1.2 内置功能
用户管理:用户是系统操作者,该功能主要完成系统用户配置。
部门管理:配置系统组织机构(公司、部门、小组),树结构展现支持数据权限。
岗位管理:配置系统用户所属担任职务。
菜单管理:配置系统菜单,操作权限,按钮权限标识等。
角色管理:角色菜单权限分配、设置角色按机构进行数据范围权限划分。
字典管理:对系统中经常使用的一些较为固定的数据进行维护。
参数管理:对系统动态配置常用参数。
通知公告:系统通知公告信息发布维护。
操作日志:系统正常操作日志记录和查询;
系统异常信息日志记录和查询。
登录日志:系统登录日志记录查询包含登录异常。
在线用户:当前系统中活跃用户状态监控。
定时任务:在线(添加、修改、删除)任务调度包含执行结果日志。
代码生成:前后端代码的生成(java、html、xml、sql)支持CRUD下载 。
系统接口:根据业务代码自动生成相关的api接口文档。
服务监控:监视当前系统CPU、内存、磁盘、堆栈等相关信息。
在线构建器:拖动表单元素生成相应的HTML代码。
连接池监视:监视当前系统数据库连接池状态,可进行分析SQL找出系统性能瓶颈。
二、环境准备
2.1 nacos
在nacos的官网下载,解压完成后,以供后期使用。
2.2 mysql
在官方文档中,mysql版本最好为5.7+,mysql5.6以下存在datetime(0)无法导入的问题,可能需要自行替换(0)->''
mysql的安装过程在这里,就不在额外赘述,大家可以查询网上资料直接安装mysql数据库。
2.3 redis
由于,现在redis不在支持windows操作系统,将redis安装在linux的虚拟机上,方便直接操作。
redis的安装过程在这里,就不在额外赘述,大家可以查询网上资料直接安装redis数据库。
推荐:在这里给大家推荐一款redis 图形页面工具-RedisDesktopManager,大家可以偷懒不用敲命令,就能方便查看redis数据
2.4 yarn
在yarn官网下载[1]yarn安装包,直接双击运行即可
在安装yarn之后,执行yarn命令,会出现下面的问题:
- yarn : 无法将“yarn”项识别为 cmdlet、函数、脚本文件或可运行程序的名称。请检查名称的拼写,如果包括路径,请确保路径正确,然后再试一次。
感谢网友的的解决方法[2]:
以管理员身份打开PowerShell,执行以下命令 set-ExecutionPolicy RemoteSigned
并设置淘宝镜像
yarn config set registry https://registry.npm.taobao.org/
2.5 host文件修改
需要在C:\Windows\System32\drivers\etc目录下的hosts文件中增加一下内容:
127.0.0.1 eureka7001.com
127.0.0.1 gateway.com
推荐: 在这里给大家推荐一个款软件SwitchHosts!,是一款非常方便切换host的开源软件
三、部署后端微服务
3.1 获取代码
若依后端代码采用采用Spring Boot、Spring Cloud & Alibaba,注册中心、配置中心选型Nacos,权限认证使用OAuth2,流量控制框架选型Sentinel。
git clone -b nacos https://gitee.com/zhangmrit/ruoyi-cloud.git
3.2 修改相关配置文件
3.2.1 导入nacos文件,并启动nacos
- 创建nacos数据库
- 导入nacos数据脚本 执行sql\nacos.sql文件,将相关配置文件导入nacos数据库
- 修改nacos配置文件 修改nacos的配置文件%nacos_home%\conf\application.properties,使其单机模式支持mysql,只需要将该文件中
- 启动nacos ,以单机的方式启动nacos。
startup.cmd -m standalone
3.2.2 创建ry_cloud数据库
创建ry_cloud数据库,执行sql\ry_cloud_0115.sql(其中,具体文件版本日期,以最新代码为准),将相关数据导入到ry_cloud库中
3.2.3 创建activiti数据库
- 创建activiti数据库 执行sql\activiti.sql,该数据库为ruoyi-activiti服务所需要的数据库
- 修改ruoyi-activiti中resources\bootstrap.yml文件中数据库链接内容
3.3 修改数据库和redis配置文件
在nacos管理系统,点击配置管理 -> 配置列表功能,选择需要修改的配置参数,点击编辑,根据自己的配置参数,修改相应的参数。 以dev环境为例,需要修改redis配置参数的文件为:
ruoyi-auth-dev.yml
ruoyi-gateway-dev.yml
ruoyi-system-dev.yml
需要修改mysql数据库配置参数的文件为:
ruoyi-system-dev.yml
ruoyi-gen-dev.yml
RuoYI在参数中配置了主从访问机制,其中从库数据库默认关闭,在本地启动时,未修改从库数据源的相关信息
3.4 使用idea打开相关程序
点击 File -> Open 选择下载代码文件中的pom.xml
加载项目之后,项目需要下载相关的依赖,就是漫长的等待,这个等待的时间会根据你是否有缓存、你的网络、你的电脑,可能还有你的人品来决定。
3.5 启动后端微服务
经过漫长的等待,接下来就是激动人心的时刻,后端应用的最后一步,启动后端微服务。后台微服务对应用的启动顺序没有要求,启动每一个应用即可,需要启动应用为:
gateway
auth
system
act
gen 代码生成 可选
dfs 文件上传 可选
程序启动完成后,idea中service中看到已经启动的微服务
可以在nacos的管理系统中看到相关服务
四、部署前端
4.1 获取代码
若依前端的代码使用ant design vue框架,从ant Design vue pro项目fork后,增加相关代码,完成若依前端程序。
git clone https://gitee.com/zhangmrit/ruoyi-ant.git
4.2 修改配置文件
在前端的程序中,需要查看vue.confog.js中网关的配置是否正确,需要修改下图中target的内容与后端网关的请求IP和端口保持一致。
在最新更新的代码中,后端的网关接口为9527,与文档中的写道的8080不一样,而且,最新的代码中相关参数已经与后端的配置保持一致,此步可以省略,此处为方便后续修改网关参数,对应修改前端访问参数,特别说明。
4.3 启动程序
从gitee更新的代码后,只需简单的执行几个命令就可以完成即可启动。
- 进入ruoyi-ant目录
# 进入ruoyi-ant目录
cd ruoyi-ant
- 安装相关依赖
# 安装相关依赖
yarn install
- 开发模式启动
#开发模式启动
yarn run serve
- 启动成功 在这里没有使用cmd命令窗口启动,使用了PowerShell进行启动,大家可以根据自己的习惯选择具体的命令窗口,效果都是一样的。
在命令窗口中显示App running at http://localhost:8000/,在浏览器中输入 http://localhost:8000/,如果能够正常显示,则前端启动成功。
注:点击确定按钮,可以正常显示相应的图片验证码,如下图所示,如果验证码显示异常或者不显示,则需要检查host文件配置是否生效
#五、基本演示
- 登录页面
- 主页面
- 用户管理
- 角色管理
- 菜单管理
六、总结
首先非常感谢开源作者为我们提供RuoYi这款产品,我们可以不用使用太多的时间完成企业内部的权限管理系统的搭建,RuoYi使用多种架构(单体应用、前后端分里的分布式架构)可供我们选择。
然后,使用nacos作为注册中心和配置中心,在环境搭建上浪费了一些时间,但是,也学到了很多知识,网络上各种大神的问题解答,让问题能够更加迅速的解决;
最后,本文章罗列了一些在环境准备时,遇到的一些问题,可能没有全部罗列,大家可以到RuoYi-Cloud/issues[3]或着RuiYi常见问题[4]中,寻找解决办法。
参考资料
[1] yarn官网下载: https://classic.yarnpkg.com/zh-Hans/docs/install#windows-stable
[2] 解决方法: https://blog.csdn.net/weixin_38883338/article/details/100054550
[3] RuoYi-Cloud/issues: https://gitee.com/y_project/RuoYi-Cloud/issues
[4] RuiYi常见问题: http://doc.rycloud.zmrit.com/#/Q&A
[5] RuoYi快速启动: http://doc.rycloud.zmrit.com/#/quick-start?id=%e7%8e%af%e5%a2%83%e5%87%86%e5%a4%87
[6] windows下Yarn安装与使用: https://blog.csdn.net/w345731923/article/details/82878525
[7] 【报错】yarn : 无法将“yarn”项识别为 cmdlet、函数、脚本文件或可运行程序的名称。请检查名称的拼写,如果包括路径,请确保路径正确,然后再试一次。 + yarn install: https://blog.csdn.net/weixin_42050406/article/details/106120618
[8] npm安装教程: https://www.cnblogs.com/lgx5/p/10732016.html
[9] Nacos支持三种部署模式: https://nacos.io/zh-cn/docs/deployment.html
[10] 若依/RuoYi-Cloud: https://gitee.com/y_project/RuoYi-Cloud
[11] wind/ruoyi-ant: https://gitee.com/zhangmrit/ruoyi-ant
[12] nacos初体验-踩坑与填坑篇: https://www.jianshu.com/p/2425c96b470a
- 上一篇:聊聊依赖管理
- 下一篇:前端自查-一定要会的NPM常用操作
相关推荐
- 使用Python编写Ping监测程序(python 测验)
-
Ping是一种常用的网络诊断工具,它可以测试两台计算机之间的连通性;如果您需要监测某个IP地址的连通情况,可以使用Python编写一个Ping监测程序;本文将介绍如何使用Python编写Ping监测程...
- 批量ping!有了这个小工具,python再也香不了一点
-
号主:老杨丨11年资深网络工程师,更多网工提升干货,请关注公众号:网络工程师俱乐部下午好,我的网工朋友。在咱们网工的日常工作中,经常需要检测多个IP地址的连通性。不知道你是否也有这样的经历:对着电脑屏...
- python之ping主机(python获取ping结果)
-
#coding=utf-8frompythonpingimportpingforiinrange(100,255):ip='192.168.1.'+...
- 网站安全提速秘籍!Nginx配置HTTPS+反向代理实战指南
-
太好了,你直接问到重点场景了:Nginx+HTTPS+反向代理,这个组合是现代Web架构中最常见的一种部署方式。咱们就从理论原理→实操配置→常见问题排查→高级玩法一层层剖开说,...
- Vue开发中使用iframe(vue 使用iframe)
-
内容:iframe全屏显示...
- Vue3项目实践-第五篇(改造登录页-Axios模拟请求数据)
-
本文将介绍以下内容:项目中的public目录和访问静态资源文件的方法使用json文件代替http模拟请求使用Axios直接访问json文件改造登录页,配合Axios进行登录请求,并...
- Vue基础四——Vue-router配置子路由
-
我们上节课初步了解Vue-router的初步知识,也学会了基本的跳转,那我们这节课学习一下子菜单的路由方式,也叫子路由。子路由的情况一般用在一个页面有他的基础模版,然后它下面的页面都隶属于这个模版,只...
- Vue3.0权限管理实现流程【实践】(vue权限管理系统教程)
-
作者:lxcan转发链接:https://segmentfault.com/a/1190000022431839一、整体思路...
- swiper在vue中正确的使用方法(vue中如何使用swiper)
-
swiper是网页中非常强大的一款轮播插件,说是轮播插件都不恰当,因为它能做的事情太多了,swiper在vue下也是能用的,需要依赖专门的vue-swiper插件,因为vue是没有操作dom的逻辑的,...
- Vue怎么实现权限管理?控制到按钮级别的权限怎么做?
-
在Vue项目中实现权限管理,尤其是控制到按钮级别的权限控制,通常包括以下几个方面:一、权限管理的层级划分...
- 【Vue3】保姆级毫无废话的进阶到实战教程 - 01
-
作为一个React、Vue双修选手,在Vue3逐渐稳定下来之后,是时候摸摸Vue3了。Vue3的变化不可谓不大,所以,本系列主要通过对Vue3中的一些BigChanges做...
- Vue3开发极简入门(13):编程式导航路由
-
前面几节文章,写的都是配置路由。但是在实际项目中,下面这种路由导航的写法才是最常用的:比如登录页面,服务端校验成功后,跳转至系统功能页面;通过浏览器输入URL直接进入系统功能页面后,读取本地存储的To...
- vue路由同页面重定向(vue路由重定向到外部url)
-
在Vue中,可以使用路由的重定向功能来实现同页面的重定向。首先,在路由配置文件(通常是`router/index.js`)中,定义一个新的路由,用于重定向到同一个页面。例如,我们可以定义一个名为`Re...
- 那个 Vue 的路由,路由是干什么用的?
-
在Vue里,路由就像“页面导航的指挥官”,专门负责管理页面(组件)的切换和显示逻辑。简单来说,它能让单页应用(SPA)像多页应用一样实现“不同URL对应不同页面”的效果,但整个过程不会刷新网页。一、路...
- Vue3项目投屏功能开发!(vue投票功能)
-
最近接了个大屏项目,产品想在不同的显示器上展示大屏项目不同的页面,做出来的效果图大概长这样...
你 发表评论:
欢迎- 一周热门
- 最近发表
- 标签列表
-
- idea eval reset (50)
- vue dispatch (70)
- update canceled (42)
- order by asc (53)
- spring gateway (67)
- 简单代码编程 贪吃蛇 (40)
- transforms.resize (33)
- redisson trylock (35)
- 卸载node (35)
- np.reshape (33)
- torch.arange (34)
- npm 源 (35)
- vue3 deep (35)
- win10 ssh (35)
- vue foreach (34)
- idea设置编码为utf8 (35)
- vue 数组添加元素 (34)
- std find (34)
- tablefield注解用途 (35)
- python str转json (34)
- java websocket客户端 (34)
- tensor.view (34)
- java jackson (34)
- vmware17pro最新密钥 (34)
- mysql单表最大数据量 (35)