在Symfony中访问wordpress博客

时间:2018-06-04 07:16:36

标签: php wordpress symfony symfony-2.8

我在Symfony web文件夹(root)中的一个名为“blog”的目录中设置了一个wordpress博客。但我无法从浏览器访问它,我收到以下错误:

"Forbidden"
"You don't have permission to access /blog/ on this server."

我的网站:www.example.com(/ web /< - symfony)

我的博客:www.example.com/blog/(/ web / blog /< - wordpress目录)

routing.yml中没有指向/ blog的路由。

如何在网络文件夹中设置我的wordpress博客并在浏览器上访问它?

PS:

app.php

use Symfony\Component\HttpFoundation\Request;

require __DIR__.'/../app/autoload.php';
include_once __DIR__.'/../app/bootstrap.php.cache';

$kernel = new AppKernel('prod', false);
$kernel->loadClassCache();
//$kernel = new AppCache($kernel);

//Request::enableHttpMethodParameterOverride();
$request = Request::createFromGlobals();
$response = $kernel->handle($request);
$response->send();
$kernel->terminate($request, $response);

app_dev.php

use Symfony\Component\Debug\Debug;
use Symfony\Component\HttpFoundation\Request;

//umask(0000);

/*if (isset($_SERVER['HTTP_CLIENT_IP'])
    || isset($_SERVER['HTTP_X_FORWARDED_FOR'])
    || !(in_array(@$_SERVER['REMOTE_ADDR'], array('127.0.0.1', '::1'), true) || PHP_SAPI === 'cli-server')
) {
    header('HTTP/1.0 403 Forbidden');
    exit('You are not allowed to access this file. Check '.basename(__FILE__).' for more information.');
}*/

require __DIR__.'/../app/autoload.php';
Debug::enable();

$kernel = new AppKernel('dev', true);
$kernel->loadClassCache();
$request = Request::createFromGlobals();
$response = $kernel->handle($request);
$response->send();
$kernel->terminate($request, $response);

网络/ htaccess的

DirectoryIndex app.php

#Options FollowSymlinks

<IfModule mod_negotiation.c>
    Options -MultiViews
</IfModule>

<IfModule mod_rewrite.c>
    RewriteEngine On

    RewriteCond %{REQUEST_URI}::$1 ^(/.+)/(.*)::\2$
    RewriteRule ^(.*) - [E=BASE:%1]

    RewriteCond %{HTTP:Authorization} .
    RewriteRule .* - [E=HTTP_AUTHORIZATION:%{HTTP:Authorization}]

    RewriteCond %{ENV:REDIRECT_STATUS} ^$
    RewriteRule ^app\.php(/(.*)|$) %{ENV:BASE}/$2 [R=301,L]

    RewriteCond %{REQUEST_FILENAME} -f
    RewriteRule .? - [L]

    RewriteCond %{REQUEST_FILENAME} -d

    RewriteRule .? %{ENV:BASE}/app.php [L]
</IfModule>

网络/博客/ htaccess的

<IfModule mod_rewrite.c>
RewriteEngine On
RewriteBase /blog/
RewriteRule ^index\.php$ - [L]
RewriteCond %{REQUEST_FILENAME} !-f
RewriteCond %{REQUEST_FILENAME} !-d
RewriteRule . /blog/index.php [L]
</IfModule>

1 个答案:

答案 0 :(得分:2)

从技术上讲,这不依赖于Symfony。

路由的第一步发生在web服务器级别(apache,nginx,symfony的内置测试服务器)。

这些配置为将对应用程序发出的每个请求发送到public/index.php

从那里Symfony接收请求并确定要完全填充它的控制器。

如果您现在要告诉应用忽略该请求,则需要将其转发到子文件夹,否则可能会导致该行的某处出现不良行为。

所以,既然你想要忽略你的子文件夹,你真的想在请求遇到Symfony之前设置这个规则。

换句话说 - 您应该考虑将子文件夹排除在服务器级别传递给public/index.php

以下是使用.htaccess - Symfony Ignore Directory in web/

为Apache提供的回答