芋道框架万字详解(前后端分离)、若依框架、yudao-cloud保姆级攻略

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
Redis 开源版,标准版 2GB
推荐场景:
搭建游戏排行榜
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
简介: 芋道框架万字详解(前后端分离)、若依框架、yudao-cloud保姆级攻略

♥️作者:小宋1021

🤵‍♂️个人主页:小宋1021主页

♥️坚持分析平时学习到的项目以及学习到的软件开发知识,和大家一起努力呀!!!

🎈🎈加油! 加油! 加油! 加油

🎈欢迎评论 💬点赞👍🏻 收藏 📂加关注+!


学习目标:芋道开发框架

来建立你的第一个低代码的SpringCloud项目吧!

目录

学习目标:芋道开发框架

一、引言

平台简介

系统功能

基础设施

研发工具

芋道参考文档

芋道源码

总结

准备阶段

后端

前端

功能实现

代码生成

数据库文件

屏蔽多余菜单

建立所需的菜单

代码生成

前端导入

后端导入

pom文件

getway加断言

yudao-module-basic-api

yudao-module-basic-biz

sql文件导入

功能演示

增删改查

查询

新增

删除

编辑

数据字典

关于postgre数据库

写在最后


一、引言

在软件开发的旅程中,我们经常面临大量重复性的增删改查(CRUD)操作,这无疑增加了工作的繁琐性和机械性。为了应对这一挑战,低代码开发平台应运而生,它们以提高开发效率为己任,尤其受到中小企业的青睐。在众多开发框架中,芋道框架以其卓越的性能和功能脱颖而出,成为开发者的新宠。

我们公司也采用芋道开发框架成功实施了多个项目。今天,我愿意分享我的使用经验,包括如何高效利用这个框架,以及在开发过程中遇到的一些挑战和解决方案,希望能帮助大家避免不必要的弯路。

下面,我将简要介绍芋道平台的核心能力及其特色功能:

  1. 高效的CRUD操作支持:芋道框架通过自动化代码生成,简化了常规的增删改查操作,让开发者能够更专注于业务逻辑的构建。
  2. 灵活的模块化设计:框架采用模块化设计,便于功能的扩展和维护,支持按需加载,提高了应用的灵活性和可维护性。
  3. 强大的集成能力:芋道框架支持与多种数据库、消息队列和第三方服务的集成,为构建复杂的企业级应用提供了坚实的基础。
  4. 用户友好的界面:提供直观的可视化界面,使得即使是非技术用户也能轻松上手,进行简单的配置和定制。
  5. 多租户架构支持:芋道框架支持多租户架构,能够满足不同客户的需求,同时保持应用的高性能和稳定性。
  6. 全面的文档和社区支持:芋道拥有详尽的开发文档和活跃的开发者社区,为开发者提供了丰富的学习资源和问题解答。
  7. 安全性保障:内置的安全机制确保了应用的数据安全和访问控制,保护企业数据不受威胁。

通过这些功能,芋道框架不仅提升了开发效率,也保证了应用的质量和性能。我们期待与大家分享更多关于芋道框架的深入使用技巧和最佳实践,共同推动软件开发的创新和进步。

平台简介

芋道,一套全部开源企业级的快速开发平台,毫无保留给个人及企业免费使用。

  • 前端采用 vue-element-admin
  • 后端采用 Spring Boot、MySQL、Redis。
  • 权限认证使用 Spring Security & Token,支持多终端认证系统。
  • 支持加载动态权限菜单,多方式轻松权限控制。
  • 高效率开发,使用代码生成器可以一键生成前后端代码。

系统功能

功能 描述
用户管理 用户是系统操作者,该功能主要完成系统用户配置
在线用户 当前系统中活跃用户状态监控,支持手动踢下线
角色管理 角色菜单权限分配、设置角色按机构进行数据范围权限划分
菜单管理 配置系统菜单,操作权限,按钮权限标识等
部门管理 配置系统组织机构(公司、部门、小组),树结构展现支持数据权限
岗位管理 配置系统用户所属担任职务
字典管理 对系统中经常使用的一些较为固定的数据进行维护
短信管理 短信渠道、短息模板、短信日志,对接阿里云、云片等主流短信平台
操作日志 系统正常操作日志记录和查询,集成 Swagger 生成日志内容
登录日志 系统登录日志记录查询,包含登录异常
错误码管理 系统所有错误码的管理,可在线修改错误提示,无需重启服务
通知公告 系统通知公告信息发布维护

基础设施

功能 描述
配置管理 对系统动态配置常用参数,支持 SpringBoot 加载
定时任务 在线(添加、修改、删除)任务调度包含执行结果日志
文件服务 支持本地文件存储,同时支持兼容 Amazon S3 协议的云服务、开源组件
API 日志 包括 RESTful API 访问日志、异常日志两部分,方便排查 API 相关的问题
MySQL 监控 监视当前系统数据库连接池状态,可进行分析SQL找出系统性能瓶颈
Redis 监控 监控 Redis 数据库的使用情况,使用的 Redis Key 管理
Java 监控 基于 Spring Boot Admin 实现 Java 应用的监控
链路追踪 接入 SkyWalking 组件,实现链路追踪
日志中心 接入 SkyWalking 组件,实现日志中心
分布式锁 基于 Redis 实现分布式锁,满足并发场景
幂等组件 基于 Redis 实现幂等组件,解决重复请求问题
服务保障 基于 Resilience4j 实现服务的稳定性,包括限流、熔断等功能
日志服务 轻量级日志中心,查看远程服务器的日志
单元测试 基于 JUnit + Mockito 实现单元测试,保证功能的正确性、代码的质量等

研发工具

功能 描述
代码生成 前后端代码的生成(Java、Vue、SQL、单元测试),支持 CRUD 下载
系统接口 基于 Swagger 自动生成相关的 RESTful API 接口文档
数据库文档 基于 Screw 自动生成数据库文档,支持导出 Word、HTML、MD 格式
表单构建 拖动表单元素生成相应的 HTML 代码

芋道参考文档

yudao-cloud 开发指南

芋道源码

yudao-cloud: ruoyi-vue-pro 全新 Cloud 版本,优化重构所有功能。基于 Spring Cloud Alibaba + Gateway + Nacos + RocketMQ + Vue & Element 实现的后台管理系统 + 用户小程序,支持 RBAC 动态权限、多租户、数据权限、工作流、三方登录、支付、短信、商城、CRM、ERP 等功能。你的 ⭐️ Star ⭐️,是作者生发的动力!

总结

可以看出来芋道开发框架是非常全能的,我也用这个框架开发了三个项目所使用的技术栈后端为SpringCloud,前端使用的是Vue3,数据库主要用的两个,MySQLpostgre,主要使用的是他的代码生成功能,在此需要注意的是芋道开发框架目前只支持MySQL的建表插入语句,其余数据库需要另做更改,我一会会去介绍postgre的使用方式。

那就让我们开始学习创建一个项目吧!

准备阶段

后端

去我上面给的链接里面下载下来然后用idea打开

如果不是企业项目的话,个人使用直接再命令行里执行这一段代码即可

git clone https://gitee.com/zhijiantianya/yudao-cloud.git

image.gif

image.gif 编辑

image.gif 编辑

image.gif 编辑

这样就下载好了,使用idea打开即可

image.gif 编辑

这就是后端打开的样子,由于这是一个SpringCloud微服务框架,每一个module模块都是一个单独的服务,可以根据自己的需求对模块来进行删除或者保留,而这个系统里的核心模块也就是一定要保留的模块分别是yudao-moudle-getway、yudao-moudle-system(系统功能模块)、yudao-moudle-infra(基础设施模块),作者也在文档中有所标注。

image.gif 编辑

可以看出来芋道框架的功能是很强大的,由于我们要做一个演示所以就把多余的功能模块删掉。

image.gif 编辑

然后把项目pom文件中的响应报红的依赖删除掉即可

image.gif 编辑

如果你在启动项目的途中遇到了“Caused by: java.net.ConnectException: Connection refused: getsockopt”这个错误说明你没有启动nacos,我们还需要启动一个nacos,没有nacos的小伙伴需要下载一个。

nacos官网

Releases · alibaba/nacos (github.com)

image.gif 编辑

这里一定要看好了要下载server版本的,要记得往下划一划,不要下载client版本的。nacos下载好以后在路径栏里输入cmd进入控制终端,输入以下语句启动nacos

startup -m standalone

image.gif 编辑

image.gif 编辑

看到上面这个页面就说明nacos启动成功了,再回到后端启动getway,就会发现启动成功了。

image.gif 编辑

然后要下载好tomcat,如果没有tomcat是没有办法启动的,下面是tomcat的链接:

Tomcat下载链接:Apache Tomcat® - Welcome!

然后还要在本地下载一个redis

redis下载链接:Redis - The Real-time Data Platform

启动redis:

image.gif 编辑

然后我们要找到对应的sql文件导入到自己的数据库里面,要看好自己是什么数据库去导入对应的数据库文件,我这里用的是mysql数据库所以就展示mysql数据库导入。

image.gif 编辑

找到这个sql文件的位置导入到我们提前建好的数据库中即可。

image.gif 编辑

都ok即可,然后我们刷新一下数据库,看看是不是多了很多表

image.gif 编辑

然后启动InfraServerApplication和SystemServerApplication模块,出现这个界面则代表后端已经启动成功了,接下来咱们启动前端项目。

image.gif 编辑

前端

我们继续去yudao-cloud 开发指南找到前端页面的下载指南,在这里我演示基于Vue3+ element-plus 版本,在安装之前我们需要在本地下载一个node.js

node.js下载地址:Node.js — Download Node.js® (nodejs.org)

下载好以后,一路next即可安装好。

image.gif 编辑

注意:一定要在本地有一个node.js要不然启动前端会报错。

然后我们克隆前端版本到本地GitHub - yudaocode/yudao-ui-admin-vue3: 芋道管理后台,基于 Vue3 + Element Plus 实现,支持 RBAC 动态权限、数据权限、SaaS 多租户、Flowable 工作流、三方登录、支付、短信、商城、CRM、ERP、AI 大模型等功能。

使用vscode打开

在终端运行以下命令:

# 安装 pnpm,提升依赖的安装速度

npm config set registry https://registry.npmjs.org

npm install -g pnpm

# 安装依赖

pnpm install

# 启动服务

npm run dev

“pnpm install”这条命令会需要一段时间,请大家耐心等待。

输入npm run dev我们即可启动芋道服务界面

如果出现以下错误则证明你的80端口被占用了,芋道系统默认打开80端口

error when starting dev server:

Error: listen EACCES: permission denied 0.0.0.0:80

   at Server.setupListenHandle [as _listen2] (node:net:1881:21)

   at listenInCluster (node:net:1946:12)

   at doListen (node:net:2116:7)

   at process.processTicksAndRejections (node:internal/process/task_queues:83:21)

我们需要去env里更改默认的80端口,改成可以用的。

image.gif 编辑

如果出现了以下错误:

22:02:05 [vite] Internal server error: getaddrinfo ENOENT raw.githubusercontent.com

     at GetAddrInfoReqWrap.onlookupall [as oncomplete] (node:dns:120:26)

22:02:05 [vite] Pre-transform error: getaddrinfo ENOENT raw.githubusercontent.com

22:02:05 [vite] Pre-transform error: getaddrinfo ENOENT raw.githubusercontent.com (x2)

解决方法:

查看raw.githubusercontent.com的真实IP地址

点开网址 https://www.ipaddress.com/ ,输入raw.githubusercontent.com,点击查询:

复制以下的ip

修改hosts文件

找到这个文件夹: C:\Windows\System32\drivers\etc 下的hosts

以管理员身份运行笔记本打开hosts,在最后一行编辑

185.199.108.133 raw.githubusercontent.com

185.199.109.133 raw.githubusercontent.com

185.199.110.133 raw.githubusercontent.com

185.199.111.133 raw.githubusercontent.com

即可

image.gif 编辑

当我们看到这个页面就证明前端启动成功了。

点击登录,如果你可以正常登陆的话就可以。

image.gif 编辑

这个就是我们点进来的界面了。那就让我们进行接下来的操作:芋道功能介绍吧~

功能实现

代码生成

我刚刚介绍了芋道的功能,在这里就不过多赘述了,我相信大家不管是学习还是在企业之中最离不开的就是增删改查了,而我们现在要介绍的就是芋道的代码生成,它可以帮我们快速的生成一张具备CURD的功能表,那就让我们快开始吧。

数据库文件

我们开发业务的时候最开始先要有的就是数据库,当然芋道是没有办法帮我们建立数据库的,数据库还是要我们自己建的,在我们建数据库的时候也有需要注意的事项:

1.设计数据库字段时每个字段的类型尽量不要错,要不然在生成代码的时候会很麻烦

2.设计数据库的时候每个字段以及表一定要有自己的注释也就是comment才可以,要不然在你生成代码的时候,芋道系统是不会接收的

3.每个表最好都要有一个主键id方便后期做一些业务查询

4.要严格遵循驼峰原则,字段名称的英文不要拼错

我在这里准备了几张表,大家如果不愿意自己建表的话,也可以用我的准备好的表,我这是一个智慧城市的表,这个项目可以记录每个小区里的人员以及小区附近的场所的功能,算是一个政府性质的项目,也是我自己在企业里开发的项目,大家仅作参考,数据库文件我就放在资源包里了。

数据库文件弄好以后我们就来看看能不能生成前后端文件。

屏蔽多余菜单

芋道自带的功能是很多的,在这里我们不展示他的功能,为了方便开发我们就屏蔽一些功能菜单,大家可以屏蔽也可以不屏蔽,我是为了简洁所以屏蔽掉。

image.gif 编辑

点击修改 image.gif 编辑

当然也可以通过用户管理更改菜单权限来屏蔽掉,都可以

image.gif 编辑

我们只需要留系统管理基础设施即可,其余的都不需要,屏蔽完成之后点击刷新菜单缓存即可。

image.gif 编辑

这样界面就会简洁不少。

建立所需的菜单

然后我们建立自己所需要的业务菜单,这里我们就建一个“居住人信息”菜单吧,建好之后点击刷新菜单缓存就可以发现已经出现在左侧导航窗格里了。

image.gif 编辑

代码生成

万事俱备,我们现在可以代码生成了!!好耶!!

点击基础设施->代码生成->导入,导入数据库文件即可,在这里我们先演示导入一个数据库文件,剩下的数据库文件大家可以当练习,如果碰到什么困难可以后台私信我,我非常愿意和大家交流以及分享我的经验,话不多说,走着~

我们就先导入这个“居住人信息这张表”,点击导入。

image.gif 编辑

点击编辑,我们按照自己的需求来进行修改,比如什么信息需要列表显示,什么信息时查询字段,什么信息需要新增,什么信息可以编辑可以查看,什么信息是下拉框以及要生成Cloud的后台还是Boot的后台,Vue3的前台还是Vue2的前台。

字段信息这样即可,当然这是你自己的项目,你也可以根据自己的想法不用按照我的例子来更改。

image.gif 编辑

image.gif 编辑

image.gif 编辑

生成信息:

image.gif 编辑

点击保存以后再次点击代码生成你就会发现自动下载了一个压缩包

image.gif 编辑

解压完成后会有三个文件,分别对应了前端、后端、数据库

image.gif 编辑

接下来让我们导入这些文件吧。

前端导入

前端导入是很容易的,我们打开yudao-ui-admin-vue3-->src-->api-->basic

image.gif 编辑

复制到我们刚刚clone下来的前端文件里的yudao-ui-admin-vue3-->src-->api中即可

image.gif 编辑

同理,前端文件中的views文件也要复制到clone下来的views文件中。

注意:一定要看好生成的api放到api下,views放到views下。

这样前端文件就搞定啦,是不是很简单。

后端导入

接下来我们进行后端导入,这是一个比较麻烦的过程,请大家要认真一点。那么我们就开始吧。

最开始我们直接把生成的yudao-module-basic这个文件直接复制到clone下来的芋道后端文件中即可,它就是一个独立的微服务模块。

image.gif 编辑

只复制过来是不够的,这里面是缺少很多东西的,让我们依次来完善

pom文件

在整个文件下的pom文件里面要加上这句话:<module>yudao-module-basic</module>

这是为了添加module拓展的

image.gif 编辑

getway加断言

点击到yudao-getway-->application.yaml文件中,给我们的basic模块加上断言

image.gif 编辑

在对应位置加上

## crm-server 服务

- id: basic-admin-api # 路由的编号

 uri: grayLb://basic-server

 predicates: # 断言,作为路由的匹配条件,对应 RouteDefinition 数组

   - Path=/admin-api/basic/**

 filters:

   - RewritePath=/admin-api/basic/v3/api-docs, /v3/api-docs # 配置,保证转发到 /v3/api-docs

注意:一定要注意对齐格式!!否则会报错

image.gif 编辑

在下面再加上这句话:

- name: basic-server

 service-name: basic-server

 url: /admin-api/basic/v3/api-docs

image.gif 编辑

同样要注意对齐格式和名字对应问题

yudao-module-basic-api

复制一个yudao-module-system-api下面的ErrorCodeConstants文件过来

image.gif 编辑

复制到这里

image.gif 编辑

把ErrorCodeConstants_手动操作里面的代码复制到ErrorCodeConstants中,并自己起一个错误代码,如下图所示:

image.gif 编辑

package cn.iocoder.yudao.module.basic.enums;


import cn.iocoder.yudao.framework.common.exception.ErrorCode;


/**

* System 错误码枚举类

*

* system 系统,使用 1-002-000-000 段

*/

public interface ErrorCodeConstants {


   // ========== 居住人信息 TODO 补充编号 ==========

   ErrorCode INFO_RESIDENT_INFORMATION_NOT_EXISTS = new ErrorCode(1_1_001_001, "居住人信息不存在");



}

记得更改package把system换成basic,然后删掉ErrorCodeConstants_手动操作这个文件即可。

复制yudao-module-system-api下的pom文件给yudao-module-basic-api,然后批量替换,ctrl+shift+r把“system”批量替换成“basic”

yudao-module-basic-biz

1.复制yudao-module-system-biz下的pom文件给yudao-module-basic-biz,然后批量替换,ctrl+shift+r把“system”批量替换成“basic”

2.把yudao-module-system-biz-->java下的三个文件复制到yudao-module-basic-biz-->java中,分别是package-info.java、SystemServerApplication(替换成BasicServerApplication)、framework下的security文件包

注意更改package-info.java把system换成basic

image.gif 编辑

改security的SecurityConfiguration这几个地方,把system都换成basic

image.gif 编辑

3.右键yudao-module-basic-biz下的pom文件点击添加到maven仓库

image.gif 编辑

4.复制yudao-module-system下的resources文件,把缺少的都复制过来

把yaml文件里这个地方的system换成basic

image.gif 编辑

bootstrap同理

image.gif 编辑

4.右键yudao-module-basic下的pom文件点击添加到maven仓库

5.尝试启动BasicServerApplication

注意:如果报D:\Desktop\workplace\yudao-cloud\yudao-module-basic\yudao-module-basic-biz\src\main\java\cn\iocoder\yudao\module\basic\controller\admin\inforesidentinformation\vo\InfoResidentInformationSaveReqVO.java:6

java: 程序包jakarta.validation.constraints不存在

这个错误的话 image.gif 编辑

挨个把爆红的语句删除即可。

如果@NotEmpty这个注解报红的话导入对应的包即可,@NotNull也是这样解决

image.gif 编辑

经过我们的一顿处理如果看到这个页面的话就代表启动成功了

在这里插一嘴,如果你端口占用的话,记得去yaml文件里改端口号哦,我改的是48083,以后每增加一个模块挨个加以即可

image.gif 编辑

server:

 port: 48083


image.gif 编辑如果看到这个页面就代表启动成功了,那让我们赶快导入sql文件爽一下把!

sql文件导入

sql文件导入是很简单的,让我们打开下载下来的生成代码的文件。

image.gif 编辑

找到sql.sql文件在数据库里执行一下即可,那个h2.sql不需要执行,那个是为了做测试用的。

执行这个sql文件的目的是把咱们生成好的菜单,以及增删改查的功能加入到system_menu这个表里,这样就可以显示出来了。

那就让我们赶紧运行一下sql文件吧。

右键数据库执行sql文件

image.gif 编辑

出现successfully就代表sql文件运行好了,刷新一下数据表就好。

image.gif 编辑

到此为止,我们所有的准备工作已经完成了,那就让我们赶快去体验一下功能吧!

功能演示

点击菜单管理,我们就会看到居住人信息旁边多了个箭头,我们打开这个箭头就会发现功能已经添加进去了。 image.gif 编辑

点击用户管理,给当前用户分配权限,然后再回到菜单刷新菜单缓存就可以看见了。以后每添加一个新的模块新的菜单都是这样操作的。

image.gif 编辑

这个就是我们的页面啦!是不是非常不容易,为自己鼓个掌!!

增删改查

这个页面的增删改查都是可以用的,非常方便

查询

image.gif 编辑

新增

image.gif 编辑

删除

image.gif 编辑

编辑

image.gif 编辑

但是页面需要自己去改,去完善,不过已经为我们提供很多方便了,我们可以基于这个页面去完善项目,实现自己的功能。

数据字典

数据字典是从系统管理-->字典管理-->新增,新增一个你想要的数据字典

image.gif 编辑

比如我想要新增一个“民族”,字典名称就是民族,字典类型最好是"nation",见名知意。 image.gif 编辑

新增成功之后在操作列点击数据,然后一个一个补充你的数据字典即可

image.gif 编辑

然后在前端改一下,v-for遍历一下你的数据字典即可。

关于postgre数据库

芋道目前只支持mysql建表语句的生成,是无法按照你的数据库去生成建表语句的,小伙伴们都知道pg数据库和mysql数据库有一些细微的差别,在这里我准备了一个把mysql建表语句自动转换成pg数据库语句的程序,我已经上传在我主页了,但是收费并非我的本意,大家可以私信我,我发给大家,在文章的最后我会附上我的微信,也欢迎大家加我的好友,我们一起交流学习!

写在最后

即使是一万个字也就只能把“保姆级攻略”做到简单的代码生成,但是芋道我已经用了有三个月了,我对芋道的认识不止于此,如果小伙伴们有任何问题也欢迎大家随时给我发私信或者加我的好友,我的微信号是:sxy0802000,大家也可以关注我的博客我会坚持分享我学到的有用的技术和知识,让我们共同成长。

最后祝大家变成路上一帆风顺,头发多多,薪水高高!

相关实践学习
基于Redis实现在线游戏积分排行榜
本场景将介绍如何基于Redis数据库实现在线游戏中的游戏玩家积分排行榜功能。
云数据库 Redis 版使用教程
云数据库Redis版是兼容Redis协议标准的、提供持久化的内存数据库服务,基于高可靠双机热备架构及可无缝扩展的集群架构,满足高读写性能场景及容量需弹性变配的业务需求。 产品详情:https://www.aliyun.com/product/kvstore &nbsp; &nbsp; ------------------------------------------------------------------------- 阿里云数据库体验:数据库上云实战 开发者云会免费提供一台带自建MySQL的源数据库&nbsp;ECS 实例和一台目标数据库&nbsp;RDS实例。跟着指引,您可以一步步实现将ECS自建数据库迁移到目标数据库RDS。 点击下方链接,领取免费ECS&amp;RDS资源,30分钟完成数据库上云实战!https://developer.aliyun.com/adc/scenario/51eefbd1894e42f6bb9acacadd3f9121?spm=a2c6h.13788135.J_3257954370.9.4ba85f24utseFl
目录
相关文章
|
开发框架 移动开发 小程序
强烈推荐:绝对是好用的小程序开源框架
强烈推荐:绝对是好用的小程序开源框架
200 0
|
8月前
|
Java Docker 容器
美团大牛精心整理SpringBoot学习笔记,从Web入门到系统架构
近期慢慢复工,为了准备面试,各路码友们都开始磨拳擦脚,背面试题、知识点。小编最近得一良友赠送了一份关于SpringBoot的学习笔记,简直不要好用,理论解析言简意赅,每一步操作都有图片展示。这么好的东西肯定不能私藏,为了感谢大家在2019年里的支持,我现在将这份笔记赠送给大家,祝大家前程似锦,Offer不断!
|
3月前
|
前端开发 Java 关系型数据库
【保姆级SSM教程】高并发朋友圈点赞项目设计
【保姆级SSM教程】高并发朋友圈点赞项目设计
56 0
|
5月前
|
缓存 Java Spring
Spring缓存实践指南:从入门到精通的全方位攻略!
【8月更文挑战第31天】在现代Web应用开发中,性能优化至关重要。Spring框架提供的缓存机制可以帮助开发者轻松实现数据缓存,提升应用响应速度并减少服务器负载。通过简单的配置和注解,如`@Cacheable`、`@CachePut`和`@CacheEvict`,可以将缓存功能无缝集成到Spring应用中。例如,在配置文件中启用缓存支持并通过`@Cacheable`注解标记方法即可实现缓存。此外,合理设计缓存策略也很重要,需考虑数据变动频率及缓存大小等因素。总之,Spring缓存机制为提升应用性能提供了一种简便快捷的方式。
66 0
|
5月前
|
Java UED 自然语言处理
Struts 2 国际化竟有如此神奇魔力?快来揭开多语言支持的 Web 应用神秘面纱
【8月更文挑战第31天】在全球化背景下,Web应用需适应多种语言环境。Struts 2凭借其强大的国际化(i18n)支持,简化了多语言应用开发。通过不同语言的资源文件,它能自动匹配用户语言偏好,优化用户体验并扩展用户群。下面是一个示例:创建`messages.properties`(英语)与`messages_zh_CN.properties`(中文),并在Struts 2的Action类及JSP页面中调用`getText()`方法及Struts标签展示相应语言内容。此外,在struts.xml中指定资源文件,以确保框架正确加载对应语言包。通过这些步骤,开发者可以轻松实现应用的多语言支持。
78 0
|
5月前
|
SQL Java 数据库连接
Spring Boot联手MyBatis,打造开发利器:从入门到精通,实战教程带你飞越编程高峰!
【8月更文挑战第29天】Spring Boot与MyBatis分别是Java快速开发和持久层框架的优秀代表。本文通过整合Spring Boot与MyBatis,展示了如何在项目中添加相关依赖、配置数据源及MyBatis,并通过实战示例介绍了实体类、Mapper接口及Controller的创建过程。通过本文,你将学会如何利用这两款工具提高开发效率,实现数据的增删查改等复杂操作,为实际项目开发提供有力支持。
351 0
|
8月前
|
人工智能 小程序 Java
基于B/S架构springboot框架开发的中小学智慧校园平台源码
基于B/S架构springboot框架开发的中小学智慧校园平台源码
122 0
|
移动开发 开发框架 前端开发
进阶攻略|前端最全的框架总结
进阶攻略|前端最全的框架总结
68 1
|
前端开发 Java 关系型数据库
IT市场寒冬过了!GitHub置顶的Spring微服务架构实战派手册有用了
“今年找工作好难啊” 感觉大家总是陷入市场寒冬这个氛围里面“无法自拔”,虽然今年经济下行,工作的确难找,但是在职友集上可查询到的Java岗位仍有20w+,需求相比其他而言并不算少,更别提还有技术细分下的岗位可选!

热门文章

最新文章