存储一部分容易被修改的配置到数据库中,方便修改
使用方法:
首先下载附件,解压后放入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(ob
8.经试验,common模块的function中无法连接数据库,所以可以在common的config.php中设置LOAD_EXT_CONFIG,然后在扩展配置中调用DC();(必须先配置数据库,扩展配置中如果没有其他配置,不用return)
DbConfig.class.rar
( 1.25 KB 下载:11 次 )
最佳答案
