使用 Hasor 实现 模版化配置文件

    Hasor 不光小巧还很精良,这一片文章我们来讲一讲 “模版化配置文件”。

    首先在了解模版化配置文件之前先看一下我们的实际开发中的问题。现在假设你有一个小团队,大家分别开发同一个项目的不同功能。通常情况下我们会为项目划分几个大模块,然后为每个模块建立一个自己的配置文件。或者干脆所有项目的配置都放到一个配置文件中。

    在这些配置信息中一般会包涵例如:文件上传路、数据库连接、远程接口服务器地址 这些配置,这些配置通常在不同的环境下有着不同的配置值,例如:日常、测试、预发、生产。

    而有些项目稍微改一下配置就回面部全非变成另外一个系统,这些配置也是跟随时机部署情况灵活改变的。

    如果你开发的是更大一点的网站,css、文件上传中心、图片服务器、等等都会独立出来。当你开发完应用程序,光是在生产环境替换这些配置信息就够你忙活一阵子了。更何况如果项目分了模块,要替换的配置文件还会更多。

    “模版化配置文件” 的提出是为了解决这个问题。

    下面我们以 数据库连接配置为例:

<config xmlns="http://project.hasor.net/hasor/schema/main">
    ...
    <jdbcSettings>
        <jdbcDriver>com.mysql.jdbc.Driver</jdbcDriver>
        <jdbcURL>jdbc:mysql://${jdbc.database_host}:3306/${jdbc.database_name}?useUnicode=true&amp;characterEncoding=utf-8</jdbcURL>
        <userName>${jdbc.user}</userName>
        <userPassword>${jdbc.password}</userPassword>
    </jdbcSettings>
    ...
</config>

    在上面这个配置中我们可以看到这样的结构“${xxxxx}” 。在 Hasor 的配置文件中,这段花括号括起来的表示的是环境变量名称。在上面这单代码中可以看到一共有 4 个环境变量配置。

${jdbc.database_host}
${jdbc.database_name}
${jdbc.user}
${jdbc.password}

    接下来我们在 classpath 目录下新建一个名为 “env.config” 的文本文件。然后把上面四个配置项保存到这里。Hasor 在启动的时候会加载 “env.config” 的配置信息,然后 Hasor 会使用这个配置信息替换配置文件中的相应配置信息。

jdbc.database_host = ...
jdbc.database_name = ...
jdbc.user          = ...
jdbc.password      = ...

    env.config 文件除了放置到 classpath 目录下还可以放到 WORK_HOME 环境变量表示的目录下也可以。如果放到 WORK_HOME 下面,您的应用程序包都不需要有任何修改了。

转载于:https://my.oschina.net/ta8210/blog/754723

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值