thinkphp5.1是否支持extra
thinkphp5.1不支持extra,thinkphp5.1中config函数已经取消了extra的支持;可以将“function editConfig($arr = [] ,$user='admin'){...}”代码贴入app或者application文件夹内的common.php中即可全局使用该函数。
本教程操作环境:Windows7系统、ThinkPHP5版、Dell G3电脑。
thinkphp5.1是否支持extra?
不支持。
ThinkPHP5.1 使用文件作为配置文件
ThinkPHP5.1 使用文件作为配置文件的踩坑记录
使用Tp5.1(版本限定)作为App后台的时候,用户频繁的请求,每一步操作都要访问数据库,每一步操作都要访问到 config 配置表,频繁的读取使数据库压力山大,在后台监控流量,发现将近30%的请求都是在访问config表,所以决定将配置固话到本地,使用文件作为配置.
但是查询多方资料,未能找到可以静态修改配置,Tp5.1提供的Config::set()函数只能动态的修改配置文件,而且仅限于本控制器内,实际配置文件并没有改变,这显然不符合我们的要求.
经查询多方资料后,发现这篇最为靠谱,但是实测无效,
进入config函数后,发现Tp5.1中,config函数已经取消了extra的支持,于是乎自己动手改写了一下
不多说,直接暴力上 代码.
/** * 修改扩展配置文件 * @param array $arr 需要更新或添加的配置 * @param string $user 修改人 * @return bool */ function editConfig($arr = [] ,$user='admin') { if (is_array($arr)) { //获取文件名 $filename = 'business.php'; //获取配置文件环境变量位置(请确保开启权限,如若报错,请改为绝对路径) $filepath = Env::get('CONFIG_PATH'). $filename; //判定配置文件是否存在 if (!file_exists($filepath) ) { if(!fopen($filepath, "w")){ return 'PermissionError1'; } } //判定权限是否足够 if (!is_writable($filepath)) { return 'PermissionError2'; } //遍历整个配置文件 $conf = include $filepath; foreach ($arr as $key => $value) { $conf[$key] = $value; } //记录修改者 $time = date('Y/m/d H:i:s'); $str = "<?php\r\n/**\r\n * 由".$user."修改.\r\n * $time\r\n */\r\nreturn [\r\n"; //写入配置文件 foreach ($conf as $key => $value) { if(is_array($value)){ $str.="\t'$key'=>[\r\n"; foreach ($value as $ikey=>$r) { if(is_numeric($ikey)){ $str .= "\t\t'$r',"; $str .= "\r\n"; }else{ $str .= "\t\t'$ikey' => '$r',"; $str .= "\r\n"; } } $str = rtrim($str,','); $str .= "\t],"."\r\n"; } else{ $str .= "\t'$key' => '$value',"; $str .= "\r\n"; } } $str .= '];'; //关闭文件 $result = file_put_contents($filepath, $str); if($result){ return 'success'; } else { return $result; } } else { return 'error'; } }
将本段代码贴入app(或者application)文件夹内的common.php中,即可全局使用该函数,进行修改配置文件.
范例:
在网站根目录的config文件夹中建立一个business.php文件(注意读写权限),
控制器中调用修改函数
public function setBusiness(){ $arr = array( "WEB" => [ "web_status"=>'1', 1,3,4 ], ); $result=editConfig($arr,'admin123'); if($result=='success'){ echo ('修改成功'); }elseif($result=='error'){ echo ('修改失败'); } elseif($result=='PermissionError'){ echo ('文件无权限,请联系管理员'); } }
config文件夹下的配置文件就会修改为
<?php /** * 由admin123修改. * 2019/11/22 13:00:27 */ return [ 'WEB'=>[ 'web_status' => '1', '1', '3', '4', ], ];
接下来,在其他控制器中,就可以直接使用config的法则来获取各种配置文件了,具体规则,请移步TP5.1手册配置获取章节.
逻辑程序直接从文件读取配置,用户读取配置,可以设置缓存或者直接从redis里读取.
推荐学习:《thinkPHP视频教程》
以上是thinkphp5.1是否支持extra的详细内容。更多信息请关注PHP中文网其他相关文章!

热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

AI Hentai Generator
免费生成ai无尽的。

热门文章

热工具

记事本++7.3.1
好用且免费的代码编辑器

SublimeText3汉化版
中文版,非常好用

禅工作室 13.0.1
功能强大的PHP集成开发环境

Dreamweaver CS6
视觉化网页开发工具

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)

本文比较了联想的思想簿和ThinkPad笔记本电脑系列。 ThinkPads优先考虑专业人士的耐用性和性能,而Thinkbooks则为日常使用提供了一种时尚,负担得起的选择。 关键区别在于构建质量,P

本文解释了如何防止ThinkPHP应用中的SQL注入。 它强调通过ThinkPhp的查询构建器使用参数化查询,避免直接的SQL串联并实现强大的输入验证和消毒。 广告

本文介绍了ThinkPHP漏洞,强调修补,预防和监视。 它详细说明了通过更新,安全补丁和代码修复处理特定漏洞的方法。 主动措施,例如安全配置,输入

本文详细介绍了ThinkPhp软件安装,涵盖了下载,提取,数据库配置和权限验证等步骤。 它解决了系统需求(PHP版本,Web服务器,数据库,扩展程序),Common installat

本教程解决了常见的thinkphp漏洞。 它强调定期更新,安全扫描仪(RIPS,Sonarqube,Snyk),手动代码审查以及识别和补救的渗透测试。 预防措施包括安全

本文展示了使用ThinkPHP的CLI功能来构建命令行应用程序(CLI)。 它强调了最佳实践,例如模块化设计,依赖注入和强大的错误处理,同时突出了诸如INSU之类的常见陷阱

本指南详细详细介绍了ThinkPHP中的数据库连接,重点介绍了通过Database.php进行配置。 它使用PDO并允许ORM或直接SQL相互作用。 该指南涵盖了对通用连接错误的故障排除,管理多个连接,EN

本文介绍了一个免费的开源PHP框架ThinkPHP。 它详细介绍了ThinkPHP的MVC架构,功能(路由,数据库互动),优点(快速开发,易用性)和缺点(潜在的过度工程,社区
