微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

ASP.NET:存储应用程序设置的位置?

最近,我发现“Web.Config文件包含< appSettings>对于存储一个应用程序设置似乎很好的部分.哎呀,它甚至有一种通过标准系统库访问文件的编程方式.所以聪明一点,我写了一个接口来访问它,然后是接口的具体实现,如下所示:
public interface IAppSettings
{
    IEnumerable<string> GetValues(string componentName,string settingName);
    IEnumerable<keyvaluePair<string,string>> GetValuePairs(string componentName,string settingName);
    void SetValues(string componentName,string settingName,IEnumerable<string> valueList,bool append);
    void SetValuePairs(string componentName,IEnumerable<keyvaluePair<string,string>> pairList,bool append);
}

然后我发现saving settings back to “web.config” while the application is running causes the entire application to re-start.这对我来说似乎完全不合理,因为如果我回写web.config并且应用程序每次都重新启动,那么像httpruntime.cache这样的东西会被完全清空,从而使我的Cache无用,因为它不断清空和重新填充.

所以我想知道:我应该在哪里存储我的应用程序设置?

有没有一个很好的解决方案,所以我不必自己滚?

编辑:

好的,感谢所有建议使用数据库和潜在表模式的人.我想我将采用以下架构:

settings:
    index NUMBER NOT NULL AUTO_INCREMENT   <== Primary Key
    component NVARCHAR(255) NOT NULL
    setting NVARCHAR(255) NOT NULL
    key   NVARCHAR(255)
    value NVARCHAR(255) NOT NULL

虽然我不认为我会“设置”P-Key,但使用Auto-Incr索引代替.这样,如果我有一个应用程序需要向多个管理器发送邮件,我可以存储许多:

index     component       setting        value
1         RequestModule   ManagerEmail   manager1@someplace
2         RequestModule   ManagerEmail   manager2@someplace

然后我可以使用:

IEnumerable<string> GetValues(string componentName,string settingName);

它将返回一个电子邮件地址列表,而不仅仅是一个值.

这有意义吗?

解决方法

web.config通常用于只读设置,即.系统管理员在部署应用程序期间设置的设置.

如果要读取和写入设置,最明显的方法是使用数据库.顺便说一句,这有一个优点:应用程序可以托管在多个服务器上,仍然可以正确读写设置,

您还可以为设置实现自定义存储,但实现起来可能更困难,而且速度也不快.

要回答第二个问题,数据库的结构取决于要存储的设置类型.

如果您需要存储异构的唯一条目,如下所示:

>管理员的邮箱地址,
>在网站主页上显示的最大条目数,
>要在“关于我们”页面显示文字,
>布尔值,指示是否启用公共注释,

那么你必须使用varchars或其他或多或少友好类型作为键来识别条目(而不是通过它们的索引来引用它们).

另一方面,如果您的目的是存储多个管理器的邮件地址,则应创建一个Manager表,其中包含其邮件地址,名称,上次连接的日期时间等.

你真的不应该混合两者.理论上,您可以通过组件/设置对参考设置中的条目.在实践中,它会使事情变得更难并产生一系列问题:

>如果您还需要为每位经理存储一个布尔值,表明她/他是否希望收到您的提醒,该怎么办?根据您当前的结构,这是不可能的.>由于相同的设置可以有多个值,您打算如何处理必须唯一的设置?例如,“关于我们”页面上只能显示一个文本值.如果数据库中存储了两个值,该怎么办?

原文地址:https://www.jb51.cc/aspnet/248483.html

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐