使用数据库存取配置(config)

浏览:1996 发布日期:2015/12/16 分类:技术分享
这样做的用处:
存储一部分容易被修改的配置到数据库中,方便修改

使用方法:
首先下载附件,解压后放入ThinkPHP\Library\Org\Util中
然后在ThinkPHP\Common\functions.php(sae模式可能不同,反正就是thinkphp的核心文件)中添加以下代码(可选):function DC($name='',$val=''){
    if(is_array($name)){
        new Org\Util\DbConfig($name['name'],$name['key'],$name['val'],$name['type'],$name['upper']);
        return Org\Util\DbConfig::read();
    }
    else if($name===''){
        new Org\Util\DbConfig();
        return Org\Util\DbConfig::read();
    }
    else{
        Org\Util\DbConfig::write($name,$val);
    }
}
使用方法:
假设你有这样一个数据库:
数据库名testconfig,字段:id,name,value,type
那么你在项目的function.php中可以使用:
DC(array('name'=>'testconfig','key'=>'name','val'=>'value','type'=>'type','upper'=>true));
来加载这个数据库中的配置
注:
1.name需要使用完整名字(带前缀)
2.upper表示是否将key转换为大写
3.默认设置:表名config,key名key,val名val,type名type,upper:true,加载配置时设置和默认设置一致的,可以省略,如上面的可以省略为DC(array('name'=>'testconfig','key'=>'name','val'=>'value'));
如所有设置都一样,可以直接使用DC()加载
4.如没有在functions中添加函数,则使用如下方式读取配置:
new Org\Util\DbConfig($name,$key,$val,$type,$upper);
Org\Util\DbConfig::read();
5.使用设置时使用thinkphp的C函数即可
6.更改配置时不能使用thinkphp的C函数,需要使用DC($name,$val)或Org\Util\DbConfig::write($name,$val);
7.目前支持的数据类型(值的类型)有:string,integer,float(double),bool,array(object)
8.经试验,common模块的function中无法连接数据库,所以可以在common的config.php中设置LOAD_EXT_CONFIG,然后在扩展配置中调用DC();(必须先配置数据库,扩展配置中如果没有其他配置,不用return)

附件 DbConfig.class.rar ( 1.25 KB 下载:11 次 )

最佳答案
评论( 相关
后面还有条评论,点击查看>>