A funcionalidade básica do Apache
mod_rewrite
pode ser simulada através da utilização de um script PHP
referenciado a partir de app.yaml
que, por sua vez, carrega o script pretendido. Este exemplo simula o padrão PHP comum que espera que a variável $_GET['q']
contenha o caminho do pedido.
Acerca de mod_rewrite.php
Para ativar a funcionalidade mod_rewrite, a sua aplicação tem de incluir o ficheiro
mod_rewrite.php
, que é o script que vai ser invocado para todos os pedidos à sua
aplicação para realizar o encaminhamento de pedidos. Conforme descrito nos comentários, o script vai verificar a existência de scripts PHP ao nível da raiz e invocá-los enquanto coloca a parte do caminho de $_SERVER['REQUEST_URI']
na variável $_GET['q']
.
<?php /** * @file * Provide basic mod_rewrite like functionality. * * Pass through requests for root php files and forward all other requests to * index.php with $_GET['q'] equal to path. The following are examples that * demonstrate how a request using mod_rewrite.php will appear to a PHP script. * * - /install.php: install.php * - /update.php?op=info: update.php?op=info * - /foo/bar: index.php?q=/foo/bar * - /: index.php?q=/ */ $path = parse_url($_SERVER['REQUEST_URI'], PHP_URL_PATH); // Provide mod_rewrite like functionality. If a php file in the root directory // is explicitly requested then load the file, otherwise load index.php and // set get variable 'q' to $_SERVER['REQUEST_URI']. if (dirname($path) == '/' && pathinfo($path, PATHINFO_EXTENSION) == 'php') { $file = pathinfo($path, PATHINFO_BASENAME); } else { $file = 'index.php'; // Provide mod_rewrite like functionality by using the path which excludes // any other part of the request query (ie. ignores ?foo=bar). $_GET['q'] = $path; } // Override the script name to simulate the behavior without mod_rewrite.php. // Ensure that $_SERVER['SCRIPT_NAME'] always begins with a / to be consistent // with HTTP request and the value that is normally provided. $_SERVER['SCRIPT_NAME'] = '/' . $file; require $file;
Exemplo de app
O exemplo seguinte mostra uma aplicação muito simples escrita para esperar $_GET['q']
.
app.yaml
Como pode ver neste ficheiro app.yaml
, esta aplicação vai fornecer dois scripts PHP de nível de raiz e disponibilizar ficheiros estáticos a partir de um diretório denominado downloads
.
application: mod_rewrite_simulator version: 1 runtime: php55 api_version: 1 handlers: # Example of handler which should be placed above the catch-all handler. - url: /downloads static_dir: downloads # Catch all unhandled requests and pass to mod_rewrite.php which will simulate # mod_rewrite by forwarding the requests to index.php?q=... (or other root-level # PHP file if specified in incoming URL. - url: /.* script: mod_rewrite.php
index.php
index.php
é um index.php
no estilo de router que lê $_GET['q']
para determinar o caminho do pedido.
<?php if ($_GET['q'] == '/help') { echo 'This is some help text.'; exit; } echo 'Welcome to the site!';
other.php
Segue-se um exemplo de um script ao nível da raiz que pode ser chamado diretamente. Muitos frameworks de PHP têm scripts como install.php
ou update.php
que se comportariam de forma semelhante.
<?php echo 'Welcome to the other site.';
Exemplos de pedidos
Tendo em conta a aplicação de exemplo acima, os seguintes pedidos seriam processados conforme apresentado.
/
traduz-se emindex.php
com$_GET['q'] = '/'
/help
traduz-se emindex.php
com$_GET['q'] = '/help'
/other.php
traduz-se emother.php
com$_GET['q'] = null
/downloads/foo_17.png
traduz-se emdownloads/foo_17.png
Evite a necessidade de mod_rewrite.php
Muitos frameworks PHP já não dependem do $_GET['q']
. Em alternativa, usam $_SERVER['REQUEST_URI']
, que funciona com e sem mod_rewrite
.
Como tal, este último é o método preferido no App Engine.
Conforme usado em mod_rewrite.php
um método simples de usar REQUEST_URI
é o seguinte:
<?php $path = parse_url($_SERVER['REQUEST_URI'], PHP_URL_PATH); if ($path == '/help') { echo 'This is some help text.'; exit; } echo 'Welcome to the site!';