1

我正在尝试将路由过滤器应用于特定的 url。所以,我的文件在公共目录下:

/public/js/kcfinder/browse.php

我的过滤器:

Route::filter('admin', function ()
{

    if (!Sentry::check())
    {
        // if not logged in, redirect to login

        return Redirect::to_route('admin_login');
    }
    elseif (!Sentry::user()->has_access('is_admin'))
    {
        //logout
        Sentry::logout();
        // has no access
        return View::make('error.access_error');
    }

});

最后我的模式:

Route::filter('pattern: js/kcfinder/*', 'admin');

如果我尝试访问

/public/js/kcfinder/browse.php

该规则不起作用。

我可以看到文件的全部内容。

如果我尝试访问

/public/js/kcfinder/blahblah.php

过滤器效果很好。因为没有文件名为

blahblah.php

目录下。

任何帮助都会非常棒!

4

2 回答 2

1

那是因为您的.htaccess文件说如果请求 URI 与现有文件匹配,则不要重写,只需按原样显示/执行文件。

所以,你有两个选择:

您可以在.htaccess文件中创建必要的过滤器,以便某些目录中的文件始终被重写并发送到index.php.

RewriteCond %{REQUEST_URI} ^/js/kcfinder
RewriteRule \.php$ index.php [L,QSA]

这个条件和规则集需要放在检查文件和目录的条件之上。

或者,您可以在 Laravel 中创建经过身份验证的路由来手动获取和执行文件。(不建议这样做,因为您必须使用eval().)

于 2013-03-26T05:36:44.640 回答
1

我一直在尝试将 ckfinder 集成到 Laravel 身份验证系统中,但最终发现这太费力了。这可能是可能的,但我的解决方案很简单。当我渲染 Ckeditor 小部件时,我在 PHP 中设置了一个普通的旧会话变量,然后在 ckfinders auth check 例程中检查会话变量是否存在。

// When rendering widget
session_start();
$_SESSION['enable_ckeditor'] = true;

// In ckfinder somewhere
session_start();
return isset( $_SESSION['enable_ckeditor'] ) ?: $_SESSION['enable_ckeditor'];
于 2013-03-26T20:19:58.000 回答