如何在laravel控制器中集成sabredav?

时间:2014-10-06 12:43:00

标签: laravel sabredav

我试图在Laravel Route中创建一个SabreDAV-Server。以下代码显示我尝试过:

Illuminate\Routing\Router::$verbs = [
    'GET',
    'HEAD',
    'POST',
    'PUT',
    'PATCH',
    'DELETE', 
    'PROPFIND',
    'PROPPATCH',
    'MKCOL',
    'COPY',
    'MOVE',
    'LOCK',
    'UNLOCK'
];


    Route::match(['GET', 'HEAD', 'POST', 'PUT', 'DELETE', 'PATCH', 'PROPFIND', 'PROPPATCH', 'MKCOL', 'COPY', 'MOVE', 'LOCK', 'UNLOCK'], 'carddav{test}', function()
{
        date_default_timezone_set('Europe/Berlin');

        $baseUri = '/carddav';

        $pdo = new PDO('mysql:host=localhost;dbname=dav', 'root', 'root');
        $pdo->setAttribute(PDO::ATTR_ERRMODE,PDO::ERRMODE_EXCEPTION);

        $authBackend = new \Sabre\DAV\Auth\Backend\PDO($pdo);
        $principalBackend = new \Sabre\DAVACL\PrincipalBackend\PDO($pdo);
        $carddavBackend = new \Sabre\CardDAV\Backend\PDO($pdo);

        $nodes = [
                new \Sabre\DAVACL\PrincipalCollection($principalBackend),
                new \Sabre\CardDAV\AddressBookRoot($principalBackend, $carddavBackend)
        ];

        $server = new \Sabre\DAV\Server($nodes);
        $server->setBaseUri($baseUri);

        $server->addPlugin(new \Sabre\DAV\Auth\Plugin($authBackend, 'SabreDAV'));
        $server->addPlugin(new \Sabre\DAV\Browser\Plugin());
        $server->addPlugin(new \Sabre\CardDAV\Plugin());
        $server->addPlugin(new \Sabre\DAVACL\Plugin());
        $server->addPlugin(new \Sabre\DAV\Sync\Plugin());

        $server->exec();
})->where('path', '(.)*';

但如果我尝试在浏览器中调用它,则会出现错误:

<?xml version="1.0" encoding="utf-8"?>
<d:error xmlns:d="DAV:" xmlns:s="http://sabredav.org/ns">
  <s:sabredav-version>2.0.4</s:sabredav-version>
  <s:exception>Sabre\DAV\Exception\NotAuthenticated</s:exception>
  <s:message>No digest authentication headers were found</s:message>
</d:error>

没有身份验证提示。

如果我尝试从Evolution连接,则会显示以下消息:&#34; Method Not Allowed&#34;。

有人知道问题是什么吗?

谢谢, 佩佩

1 个答案:

答案 0 :(得分:1)

问题是发送的HTTP状态代码。无论SabreDAV的响应如何,Laravel路由器总是将HTTP状态代码设置为200,因此任何CardDAV客户端都不会知道他们必须授权请求 - 忽略基本身份验证挑战。

我的解决方案可能不是最优雅的解决方案,但它正在发挥作用。只需将$ server-&gt; exec()包装在ob_start()和ob_end()标记中,然后使用真正的Laravel响应输出内容:

public aspect CurrentTimeInMillisMethodCallChanger {
    long around(): 
    call(public static native long java.lang.System.currentTimeMillis()) {
         //provide my own implementation 
    }
}

一般指导:

  • 使用&#34; postman&#34; (谷歌Chrome应用程序)测试请求,你会发现他们在预先发送授权标题时工作
  • 使用网络调试代理,例如&#34; Charles&#34;监控实际的请求和响应机构