Struts2自定义属性配置全攻略
本文深入讲解了在 Struts2 框架中如何优雅地实现外部化配置管理——虽无 Spring Boot 那样的 `@Value` 或 `@ConfigurationProperties` 原生支持,但通过将配置文件(如 `application.properties`)注册为全局资源包并结合 `getText()` 方法读取,即可轻松、安全、规范地管理应用级属性(如 `application.id`、`api.timeout` 等),同时明确划清敏感信息边界、提供多环境适配建议及自定义 `TextProvider` 的进阶扩展路径,助你在传统企业级 Struts2 项目中构建清晰、可维护且符合框架哲学的配置体系。
Struts2 不提供类似 Spring Boot 的 `@Value` 或 `@ConfigurationProperties` 原生支持,但可通过 `struts.properties`、全局资源包(`struts.custom.i18n.resources`)及自定义 `TextProvider` 灵活管理应用级配置项(如 `applicationId`、`timeout`),兼顾可维护性与安全性。
在 Struts2 中,配置外部化属性的核心思路是将配置视为“本地化资源”(i18n resources)进行加载与解析,而非直接注入字段。这虽与 Spring Boot 的声明式注入风格不同,但通过合理设计,同样能实现类型安全、集中管理和运行时可访问的配置体系。
✅ 推荐方案:使用全局资源包(Global Resource Bundles)
这是最简洁、标准且符合 Struts2 设计哲学的方式,适用于存储非敏感的标识类配置(如 applicationId、api.timeout、service.endpoint 等)。
步骤 1:创建配置文件
新建 src/main/resources/application.properties(或 .properties 格式):
# application.properties application.id=prod-2024-webapp api.timeout=30000 thirdparty.service.url=https://api.example.com/v1
⚠️ 注意:.properties 文件不支持 YAML 格式;若需分环境配置,建议通过 Maven Profile 或构建时替换实现,Struts2 本身不内置多环境配置机制。
步骤 2:注册为全局资源包
在 struts.xml 中声明(推荐方式):
<struts> <!-- 启用全局资源模式(禁用包级扫描,提升性能) --> <constant name="struts.localizedTextProvider" value="global-only" /> <!-- 指定全局资源文件(支持逗号分隔多个) --> <constant name="struts.custom.i18n.resources" value="application" /> </struts>
✅ value="application" 表示加载 application.properties(无需写扩展名),Struts2 会自动按 ClassLoader.getResourceAsStream("application.properties") 查找。
步骤 3:在 Action 中读取配置
所有继承 ActionSupport 的 Action 均可直接调用 getText() 方法获取值(返回 String,需自行转换类型):
public class ApiCallAction extends ActionSupport {
private String appId;
private int timeoutMs;
@Override
public String execute() throws Exception {
this.appId = getText("application.id"); // → "prod-2024-webapp"
this.timeoutMs = Integer.parseInt(getText("api.timeout")); // → 30000
// 使用配置调用第三方 API...
return SUCCESS;
}
}? 提示:getText(key) 在找不到 key 时默认返回原 key 字符串(如 "application.id"),便于快速发现配置遗漏;可通过重载 getText(key, defaultValue) 提供兜底值。
? 安全性说明:纯标识类属性可安全存放于 properties 文件
- ✅ 适用场景:applicationId、clientCode、timeout、endpoint URL 等不包含密钥、令牌、密码或私钥的公开/半公开标识信息;
- ❌ 禁止存放:API Keys、JWT Secrets、Database Passwords、OAuth Client Secrets 等敏感凭证;
- ✅ 增强建议:
- 将敏感配置移至 JVM 系统属性(-Dapi.key=xxx)或环境变量,并通过 System.getProperty("api.key") 读取;
- 结合 Filter 或 Interceptor 实现启动时校验关键配置是否存在;
- 使用 Maven profiles + resources filtering 实现不同环境打包不同 application.properties。
? 进阶:自定义 TextProvider(按需扩展)
当需要更复杂的配置逻辑(如从数据库、Consul 或加密文件动态加载),可实现自定义 TextProvider:
public class DbBackedTextProvider extends DefaultTextProvider {
private final ConfigService configService; // 自定义服务
public DbBackedTextProvider(ConfigService configService) {
this.configService = configService;
}
@Override
public String getText(String key, String defaultValue, Locale locale) {
String value = configService.findValueByKey(key);
return StringUtils.defaultString(value, defaultValue);
}
}并在 struts.xml 中注册:
<bean type="com.opensymphony.xwork2.TextProvider"
name="dbTextProvider"
class="com.example.DbBackedTextProvider"
scope="singleton" />
<constant name="struts.localizedTextProvider" value="dbTextProvider" />✅ 总结对比表
| 特性 | Spring Boot (@Value) | Struts2(推荐方案) |
|---|---|---|
| 配置文件 | application.properties / application.yml | application.properties(需注册为 i18n resource) |
| 注入方式 | 字段级注解(@Value("${key}")) | Action 内 getText("key") 调用 |
| 类型转换 | 自动(支持 int, boolean, Duration 等) | 需手动解析(Integer.parseInt() 等) |
| 多环境支持 | 原生(application-dev.yml) | 需构建时处理(Maven profiles / CI 变量替换) |
| 敏感信息防护 | 支持 @ConfigurationProperties + @Validated | 强烈建议分离敏感项至系统属性/环境变量 |
掌握这一模式,你就能在 Struts2 项目中构建清晰、可维护、符合框架规范的配置管理体系——无需引入额外依赖,也无需违背 MVC 分层原则。
终于介绍完啦!小伙伴们,这篇关于《Struts2自定义属性配置全攻略》的介绍应该让你收获多多了吧!欢迎大家收藏或分享给更多需要学习的朋友吧~golang学习网公众号也会发布文章相关知识,快来关注吧!
微信登录入口2026最新官网地址
- 上一篇
- 微信登录入口2026最新官网地址
- 下一篇
- 贝壳找房多房源对比怎么用
-
- 文章 · java教程 | 53分钟前 |
- Java开发新闻平台教程详解
- 270浏览 收藏
-
- 文章 · java教程 | 58分钟前 |
- Thread.interrupt()的作用及线程停止方法详解
- 208浏览 收藏
-
- 文章 · java教程 | 1小时前 |
- JavaPriorityBlockingQueue线程安全原理详解
- 402浏览 收藏
-
- 文章 · java教程 | 1小时前 |
- Java信号量并发控制实用技巧
- 441浏览 收藏
-
- 文章 · java教程 | 1小时前 |
- 大文件行级比对:哈希去重与查找技巧
- 458浏览 收藏
-
- 文章 · java教程 | 1小时前 |
- Java子线程异常处理方法详解
- 443浏览 收藏
-
- 文章 · java教程 | 1小时前 |
- Java爬虫教程:URL连接与流处理详解
- 388浏览 收藏
-
- 文章 · java教程 | 1小时前 |
- JIT编译器C1C2分层机制解析
- 103浏览 收藏
-
- 文章 · java教程 | 2小时前 |
- 判断Java中文字符Unicode范围的方法
- 230浏览 收藏
-
- 文章 · java教程 | 2小时前 |
- 原子类怎么用?无锁操作原理详解
- 413浏览 收藏
-
- 文章 · java教程 | 2小时前 |
- Java通知公告模块开发教程
- 477浏览 收藏
-
- 文章 · java教程 | 2小时前 |
- Java线程池任务积压解决与监控方法
- 268浏览 收藏
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 543次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 516次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 500次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 485次学习
-
- ChatExcel酷表
- ChatExcel酷表是由北京大学团队打造的Excel聊天机器人,用自然语言操控表格,简化数据处理,告别繁琐操作,提升工作效率!适用于学生、上班族及政府人员。
- 4178次使用
-
- Any绘本
- 探索Any绘本(anypicturebook.com/zh),一款开源免费的AI绘本创作工具,基于Google Gemini与Flux AI模型,让您轻松创作个性化绘本。适用于家庭、教育、创作等多种场景,零门槛,高自由度,技术透明,本地可控。
- 4529次使用
-
- 可赞AI
- 可赞AI,AI驱动的办公可视化智能工具,助您轻松实现文本与可视化元素高效转化。无论是智能文档生成、多格式文本解析,还是一键生成专业图表、脑图、知识卡片,可赞AI都能让信息处理更清晰高效。覆盖数据汇报、会议纪要、内容营销等全场景,大幅提升办公效率,降低专业门槛,是您提升工作效率的得力助手。
- 4419次使用
-
- 星月写作
- 星月写作是国内首款聚焦中文网络小说创作的AI辅助工具,解决网文作者从构思到变现的全流程痛点。AI扫榜、专属模板、全链路适配,助力新人快速上手,资深作者效率倍增。
- 6055次使用
-
- MagicLight
- MagicLight.ai是全球首款叙事驱动型AI动画视频创作平台,专注于解决从故事想法到完整动画的全流程痛点。它通过自研AI模型,保障角色、风格、场景高度一致性,让零动画经验者也能高效产出专业级叙事内容。广泛适用于独立创作者、动画工作室、教育机构及企业营销,助您轻松实现创意落地与商业化。
- 4782次使用
-
- 提升Java功能开发效率的有力工具:微服务架构
- 2023-10-06 501浏览
-
- 掌握Java海康SDK二次开发的必备技巧
- 2023-10-01 501浏览
-
- 如何使用java实现桶排序算法
- 2023-10-03 501浏览
-
- Java开发实战经验:如何优化开发逻辑
- 2023-10-31 501浏览
-
- 如何使用Java中的Math.max()方法比较两个数的大小?
- 2023-11-18 501浏览

