我有一个框架,在sabredav可以在PUT上得到它之前,它会消耗掉php://input。
是否有一种在Sabre\HTTP\Request中调用Sabre\HTTP\Request()的方法,以便我可以从框架(http://kohanaframework.org)传递它,这样getBody()就不会尝试从空白 php://input获得它
我想避免对Sabre\DAV\Server和/或Sabre\HTTP\Request进行黑客攻击,但不确定最好的方法是什么。
框架“包装”代码在这里(在Sabredav示例中实现server.php )
https://github.com/chrisgo/kohana-sabredav/blob/master/classes/Kohana/Controller/Webdav.php
发布于 2013-12-20 06:08:57
最干净的解决方案似乎是创建一个插件来拦截PUT方法,并将主体设置回sabredav所期望的位置。
public function httpPutInterceptor($method, $uri) {
$this->server->httpRequest->setBody($this->body);
}完整模块:https://github.com/chrisgo/kohana-sabredav
..。现在,我只需要弄清楚为什么nginx在二进制文件PUT上返回405,而文本文件PUT返回405(正确的行为,将其传递给PHP)。
https://stackoverflow.com/questions/20694276
复制相似问题