DataConfig.cs 4.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118
  1. using System;
  2. using System.Collections.Generic;
  3. using System.Linq;
  4. using System.Text;
  5. using System.Web;
  6. using System.Xml;
  7. using System.ComponentModel;
  8. using System.Configuration;
  9. namespace Ant.Common
  10. {
  11. public class DataConfig
  12. {
  13. public static Dictionary<string, AppSettings> AppSettingsList = new Dictionary<string, AppSettings>(); private static object lockHelper = new object();
  14. /// <summary>
  15. /// 获取数据库配置
  16. /// </summary>
  17. /// <returns></returns>
  18. public static Dictionary<string, AppSettings> GetDataConfig()
  19. {
  20. string path = string.Empty ;//"G:\\集成项目\\ORM最新源码\\ORMCodeNew\\HouXingBBS.Admin\\App_Data\\Config\\DataAccess.config"
  21. string IsWinForm = string.Empty;
  22. IsWinForm = ConfigurationManager.AppSettings["IsWinForm"].IsEmpty() ? "" : ConfigurationManager.AppSettings["IsWinForm"];
  23. if (string.Compare(IsWinForm, "true", true) == 0)
  24. {
  25. path = System.IO.Directory.GetCurrentDirectory() + ConfigurationManager.AppSettings["DataConfigUrl"];//取WindForm的配置路径
  26. }
  27. else
  28. {
  29. path = HttpContext.Current.Server.MapPath(ConfigurationManager.AppSettings["DataConfigUrl"]);
  30. }
  31. var xml = LoadXmlHelper.XmlLoading(path); DataConfiguration mod = new DataConfiguration();
  32. var xmllist = xml.SelectNodes("configuration/AppSettings");
  33. foreach (XmlElement xmlstr in xmllist)
  34. {
  35. var configModel = SerializationHelper.XmlDeserialize<AppSettings>(xmlstr.InnerXml);
  36. if (configModel.IfNotNull())
  37. {
  38. if (!AppSettingsList.ContainsKey(configModel.DatabaseName))
  39. {
  40. lock (lockHelper)
  41. {
  42. if (!AppSettingsList.ContainsKey(configModel.DatabaseName))
  43. {
  44. AppSettingsList.Add(configModel.DatabaseName, configModel);
  45. }
  46. }
  47. }
  48. }
  49. }
  50. return AppSettingsList;
  51. }
  52. /// <summary>
  53. /// 获取数据库配置
  54. /// </summary>
  55. /// <returns></returns>
  56. public static Dictionary<string, AppSettings> GetDataConfig(string path)
  57. {
  58. //string path = HttpContext.Current.Server.MapPath(ConfigurationManager.AppSettings["DataConfigUrl"]);
  59. var xml = LoadXmlHelper.XmlLoading(path); DataConfiguration mod = new DataConfiguration();
  60. var xmllist = xml.SelectNodes("configuration/AppSettings");
  61. foreach (XmlElement xmlstr in xmllist)
  62. {
  63. var configModel = SerializationHelper.XmlDeserialize<AppSettings>(xmlstr.InnerXml);
  64. if (configModel.IfNotNull())
  65. {
  66. if (!AppSettingsList.ContainsKey(configModel.DatabaseName))
  67. AppSettingsList.Add(configModel.DatabaseName, configModel);
  68. }
  69. }
  70. return AppSettingsList;
  71. }
  72. }
  73. public enum DataConfigEnum
  74. {
  75. [Description("读库")]
  76. ReadData = 0,
  77. [Description("写库")]
  78. WriteData = 1
  79. }
  80. public class DataConfiguration
  81. {
  82. }
  83. public class AppSettings
  84. {
  85. /// <summary>
  86. /// 数据库名称
  87. /// </summary>
  88. public string DatabaseName { get; set; }
  89. /// <summary>
  90. /// 数据类型
  91. /// </summary>
  92. public string DatabaseType { get; set; }
  93. /// <summary>
  94. /// 量否加密
  95. /// </summary>
  96. public string IsConStringEncrypt { get; set; }
  97. /// <summary>
  98. /// 密匙
  99. /// </summary>
  100. public string DatabaseKey { get; set; }
  101. /// <summary>
  102. /// 读库
  103. /// </summary>
  104. public string ReadData { get; set; }
  105. /// <summary>
  106. /// 写库
  107. /// </summary>
  108. public string WriteData { get; set; }
  109. }
  110. }