这篇文章将为大家详细讲解有关ThinkPHP 5.1修改缓存源码的示例分析,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。
<强> ThinkPHP 5.1修改缓存源码强>
导语
最近在学习ThinkPHP 5.1,看了缓存方法的操作,有一点疑惑。虽然封装了很多方法,使用的时候很方便,但是对复述的高级操作好像不是很友好,出于学习的目的,对源码进行了一点小修改。首先声明两点:一是此次的修改,只是个人观点,不适于所有人;二是此次修改仅为学习所用,各位谨慎<强>修改源码强>。
问题
在练习复述的时候,发现如果想要使用高级方法,例如<代码> hSet 代码>,<代码> hGet> 代码等,要先返回句柄,然后才能执行。如下
& lt; php ? namespace app \指数\控制器; use 认为\缓存\司机\复述; use 认为\控制器; class RedisTest  extends 控制器 { ,,,public function 指数() ,,,{ ,,,,,,,redis 美元;=,new 复述(); ,,,,,,,redis 美元;=,复述,美元→处理程序(); ,,,,,,,转储(复述→美元hSet (& # 39; h_name& # 39;,, & # 39; 1 & # 39;,, & # 39;汤姆# 39;));//,int (1) ,,,} }
可以看的到,执行成功。问题是为什么要先返回句柄,可以用<代码> __call 代码>这种魔术方法来解决的。
追踪源码
既然有了疑惑,就要解惑。追踪着源码,看到<代码> thinkphp/图书馆/认为/缓存/司机。php代码> ,发现确实没有<代码> __call> 代码,只是<代码>处理程序> 代码来返回句柄来执行高级方法。没想明白为什么不用<代码> __clss> 代码。
解决问题
解决方法就是在<代码> thinkphp/图书馆/认为/缓存/司机。php代码>,中添加<代码> __call 代码>方法,这样不止复述,可以直接使用高级方法,其他继承此文件的缓存类都可以直接使用。代码如下
,,,,,/* * ,,,,*,执行高级方法 ,,,,*,@param $方法 ,,,,*,@param $参数 ,,,,*,@return 混合 ,,,*/,,,public function __call(方法,美元,美元参数) ,,,{ ,,,,,,,return 中的call_user_func_array(数组($ this→处理程序(),美元方法),,美元参数); ,,,}
再看下测试代码
& lt; php ? namespace app \指数\控制器; use 认为\缓存\司机\复述; use 认为\控制器; class RedisTest  extends 控制器 { ,,,public function 指数() ,,,{ ,,,,,,,redis 美元;=,new 复述();//,,,,,,,,redis 美元;=,复述,美元→处理程序(); ,,,,,,,转储(复述→美元hSet (& # 39; h_name& # 39;,, & # 39; 2 & # 39;,, & # 39;杰瑞# 39;));//,int (1) ,,,} }
到此问题已解决。当我修改完的时候,想起Laravel似乎就是用的<代码> __call> 代码,然后去看了源码,确实如此。在<代码>拉威尔/供应商/Laravel/框架/src/照明/复述/RedisManager。php代码>中有如下代码
,,,,,/* * ,,,,*,Pass methods onto 从而default Redis 连接。 ,,,, ,,,,*,@param string 美元,方法 ,,,,*,@param , array 美元参数 ,,,,*,@return 混合 ,,,*/,,,public function __call(方法,美元,美元参数) ,,,{ ,,,,,,,return $ this→连接()→{$方法}(…$参数); ,,,}
关于“ThinkPHP 5.1修改缓存源码的示例分析”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,使各位可以学到更多知识,如果觉得文章不错,请把它分享出去让更多的人看的到。