当前位置:首页 > 文章列表 > 文章 > java教程 > Struts2自定义属性配置全攻略

Struts2自定义属性配置全攻略

2026-03-18 14:06:47 0浏览 收藏
本文深入讲解了在 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.ymlapplication.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最新官网地址
上一篇
微信登录入口2026最新官网地址
贝壳找房多房源对比怎么用
下一篇
贝壳找房多房源对比怎么用
查看更多
最新文章
资料下载
查看更多
课程推荐
  • 前端进阶之JavaScript设计模式
    前端进阶之JavaScript设计模式
    设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
    543次学习
  • GO语言核心编程课程
    GO语言核心编程课程
    本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
    516次学习
  • 简单聊聊mysql8与网络通信
    简单聊聊mysql8与网络通信
    如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
    500次学习
  • JavaScript正则表达式基础与实战
    JavaScript正则表达式基础与实战
    在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
    487次学习
  • 从零制作响应式网站—Grid布局
    从零制作响应式网站—Grid布局
    本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
    485次学习
查看更多
AI推荐
  • ChatExcel酷表:告别Excel难题,北大团队AI助手助您轻松处理数据
    ChatExcel酷表
    ChatExcel酷表是由北京大学团队打造的Excel聊天机器人,用自然语言操控表格,简化数据处理,告别繁琐操作,提升工作效率!适用于学生、上班族及政府人员。
    4178次使用
  • Any绘本:开源免费AI绘本创作工具深度解析
    Any绘本
    探索Any绘本(anypicturebook.com/zh),一款开源免费的AI绘本创作工具,基于Google Gemini与Flux AI模型,让您轻松创作个性化绘本。适用于家庭、教育、创作等多种场景,零门槛,高自由度,技术透明,本地可控。
    4529次使用
  • 可赞AI:AI驱动办公可视化智能工具,一键高效生成文档图表脑图
    可赞AI
    可赞AI,AI驱动的办公可视化智能工具,助您轻松实现文本与可视化元素高效转化。无论是智能文档生成、多格式文本解析,还是一键生成专业图表、脑图、知识卡片,可赞AI都能让信息处理更清晰高效。覆盖数据汇报、会议纪要、内容营销等全场景,大幅提升办公效率,降低专业门槛,是您提升工作效率的得力助手。
    4419次使用
  • 星月写作:AI网文创作神器,助力爆款小说速成
    星月写作
    星月写作是国内首款聚焦中文网络小说创作的AI辅助工具,解决网文作者从构思到变现的全流程痛点。AI扫榜、专属模板、全链路适配,助力新人快速上手,资深作者效率倍增。
    6055次使用
  • MagicLight.ai:叙事驱动AI动画视频创作平台 | 高效生成专业级故事动画
    MagicLight
    MagicLight.ai是全球首款叙事驱动型AI动画视频创作平台,专注于解决从故事想法到完整动画的全流程痛点。它通过自研AI模型,保障角色、风格、场景高度一致性,让零动画经验者也能高效产出专业级叙事内容。广泛适用于独立创作者、动画工作室、教育机构及企业营销,助您轻松实现创意落地与商业化。
    4782次使用
微信登录更方便
  • 密码登录
  • 注册账号
登录即同意 用户协议隐私政策
返回登录
  • 重置密码