gpt4 book ai didi

php - 方法链劫持

转载 作者:塔克拉玛干 更新时间:2023-11-03 05:45:55 25 4
gpt4 key购买 nike

这不是一个真正流畅的界面。我有一个构建方法堆栈的对象。它由单个函数调用执行。但现在我可能会添加另一个虚拟方法,它“接管”了那个方法堆栈。


用例:我将超全局变量包装到对象中。这允许我“强制”输入过滤。 $_GET 和 co 提供了简单的清理方法。我的新版本现在允许链接原子过滤器。例如:

$_GET->ascii->nocontrol->text["field"]

这是一个方法调用。它使用尖括号。但这只是一个很好的技巧,可以简化 $_GET["field"] 的重写。无论如何。

现在偶尔也有带有枚举字段的表单,如字段[0]、字段[1]、字段[2]。这就是为什么我添加了一个 virtual ->array 过滤方法。它劫持收集的方法堆栈,并迭代剩余的过滤器,例如$_POST 数组值。例如 $_POST->array->int["list"]

稍微缩短了实现时间:

function exec_chain ($data) {
...
while ($filtername = array_pop($this->__filter)) {
...
$data = $this->{"_$filtername"} ($data);
...
}

function _array($data) {
list($multiplex, $this->__filter) = array($this->__filter, array());
$data = (array) $data;
foreach (array_keys($data) as $i) {
$this->__filter = $multiplex;
$data[$i] = $this->exec_chain($data[$i]);
}
return $data;
}

方法堆栈在 $this->__filter 列表中组装。上面的 exec_chain() 只是循环遍历它,每次都删除第一个方法名称。虚拟 _array 处理程序通常是第一个方法。它只是窃取该方法堆栈,并在每个数组元素上重新执行其余部分。与上面的示例代码不完全一样,但它只是重复地重新填充原始方法堆栈。

它有效。但是感觉有点不干净。我正在考虑添加另一个虚拟方法 ->xor。 (YAGNI?)这不仅会遍历字段,还会评估替代过滤器是否成功。例如 $_REQUEST->array->xor->email->url["fields"]。我想知道是否有更好的模式来劫持函数列表。我当前的 Hook 列表 ($this->__filter) 交换不适合链接。嗯,实际上,->xor 示例不需要迭代/表现得与 ->array 完全一样。

具体来说,我有兴趣找到一种替代方法来替代我的 $this->__filter 列表用法和 array_pop() 并偷偷摸摸地换掉它。这是不好的。有没有更好的实现方案来执行一个方法列表一半是我 -> 一半是你?

最佳答案

我以前做过类似的链接界面,我喜欢你在 GET/POST 变量上使用它的想法。

我认为你最好做类似的事情

$var->array->email_XOR_url;
而不是
$var->array->email->XOR->url;
.这样您就可以使用 __get/__call 魔法捕获各种组合。

关于php - 方法链劫持,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/3848041/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com