博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Discuz NT 架构剖析之Config机制
阅读量:7286 次
发布时间:2019-06-30

本文共 3534 字,大约阅读时间需要 11 分钟。

  接触了Discuz NT! 一段时间了,是时候做个总结了,标题好霸气,有木有? 都是托园子里的大牛代振军的福啊,哈哈哈哈。

  首先论坛的信息不是完全存储在数据库里面的,一部分信息存储在config文件里面,一部分信息存储在数据库里面。

这些信息都是在后台进行配置的信息,比如论坛的基础信息,不同的CONFIG文件,有不同的组合方式。那么你可能会问,这些CONFIG文件是怎么被取到的呢?

在Discuz.Config里面有相应的介绍,我们打开一个名为APIConfig的类

public class APIConfigs    {        ///         /// 获取配置类实例        ///         /// 
public static APIConfigInfo GetConfig() { return APIConfigFileManager.LoadConfig(); } /// /// 保存配置类实例 /// ///
public static bool SaveConfig(APIConfigInfo apiconfiginfo) { APIConfigFileManager acfm = new APIConfigFileManager(); APIConfigFileManager.ConfigInfo = apiconfiginfo; return acfm.SaveConfig(); } }

其中的GetConfig()方法是调用了另一个静态方法:APIConfigFileManager.LoadConfig()

///         /// 返回配置类实例        ///         /// 
public static APIConfigInfo LoadConfig() { ConfigInfo = DefaultConfigFileManager.LoadConfig(ref m_fileoldchange, ConfigFilePath, ConfigInfo); return ConfigInfo as APIConfigInfo; }

可以发现,其实是调用了 DefaultConfigFileManager.LoadConfig方法

其中LoadConfig方法是通过代入如下参数或者方法

1.文件加载时间

2.文件物理路径

3.判断是否检查更新文件加载时间变量

4.如果我们代入了一个对象,那么这个对象必定有它的类型,通过反射我们可以获取它的类型

在Discuz.Config中,我们所做的工作都是为了把加载的配置文件反序列化成我们需要的对象。

如果checkTime为true的时候,首先会检查一下文件的最后写入时间,然后用代入的时间和这个时间对比,如果2者不相等,就会把以最后写入时间为准。

m_lockHelper的作用是为了防止多个管理员同时调用这个方法造成的结果不固定;如果谁先调用了这个方法,那么直到这个方法调用结束以前其他人无法进入此线程。

protected static IConfigInfo LoadConfig(ref DateTime fileoldchange, string configFilePath, IConfigInfo configinfo, bool checkTime)        {            lock (m_lockHelper)            {                m_configfilepath = configFilePath;                m_configinfo = configinfo;                if (checkTime)                {                    DateTime m_filenewchange = System.IO.File.GetLastWriteTime(configFilePath);                    //当程序运行中config文件发生变化时则对config重新赋值                    if (fileoldchange != m_filenewchange)                    {                        fileoldchange = m_filenewchange;                        m_configinfo = DeserializeInfo(configFilePath, configinfo.GetType());                    }                }                else                    m_configinfo = DeserializeInfo(configFilePath, configinfo.GetType());                return m_configinfo;            }        }

DeserilizeInfo可以反序列化指定类型,从细节上来说,返回一个IConfigInfo可以让我们尝试转换变得更加的简单。Load中的FileStream只是用来读取图片流而已,且基于.Net Framework实现的。XmlSerializer可以处理不同Type的实现,并支持文件流的序列化。

///         /// 反序列化指定的类        ///         /// config 文件的路径        /// 相应的类型        /// 
public static IConfigInfo DeserializeInfo(string configfilepath, Type configtype) { return (IConfigInfo)SerializationHelper.Load(configtype, configfilepath); } /// /// 反序列化 /// /// 对象类型 /// 文件路径 ///
public static object Load(Type type, string filename) { FileStream fs = null; try { // open the stream... fs = new FileStream(filename, FileMode.Open, FileAccess.Read, FileShare.ReadWrite); XmlSerializer serializer = new XmlSerializer(type); return serializer.Deserialize(fs); } catch(Exception ex) { throw ex; } finally { if(fs != null) fs.Close(); } }

 

转载于:https://www.cnblogs.com/kmsfan/p/5241428.html

你可能感兴趣的文章
SQL语法2
查看>>
grub应用
查看>>
test
查看>>
linux配置Yum源
查看>>
So what, So TM what?
查看>>
我的友情链接
查看>>
动画编辑器的使用
查看>>
shell中命令间的逻辑关系
查看>>
空间地理信息产业:看好GIS“基础平台+应用开发”模式
查看>>
python 分割list
查看>>
Redhat 5.4搭建 DNS服务器解析负载
查看>>
m283屏幕花屏问题
查看>>
FreeBSD与Linux的比较
查看>>
redis配置文件全解及常用命令
查看>>
Zabbix汇总分组流量
查看>>
BootStrap之基础-1 BootStrap起步(基本概念、环境搭建)
查看>>
linux自学笔记--bash特性
查看>>
Linux平台中设置文件的执行、写权限
查看>>
CentOS7-虚拟网卡的删除
查看>>
Ruby中的include和extend
查看>>