2014-06-06 126 views
0

所以我的staff.php?action=[action]文件被重写为/staff/[action],其中action可以取3个值new/edit/deleteApache mod_rewrite查询字符串

我想在提交时显示成功或失败消息。我试图重定向到/staff/new&error=[error]/staff/new?error=[error]

但是,var_dump($_GET)只返回action的查询字符串。

我找到的唯一解决方案是/staff?action=[action]&error=[error],但我不喜欢它。有什么方法可以重写我的规则吗?

我不想/staff/new/error/[error]

## hide .php extension snippet 
# To externally redirect /dir/foo.php to /dir/foo 
RewriteCond %{THE_REQUEST} ^[A-Z]{3,}\s([^.]+)\.php [NC] 
RewriteRule^%1 [R,L] 
# To internally forward /dir/foo to /dir/foo.php 
RewriteCond %{REQUEST_FILENAME} !-d 
RewriteCond %{REQUEST_FILENAME}.php -f 
RewriteRule ^(.*?)/?$ $1.php [L] 

RewriteRule ^staff/(.+)$ /staff.php?action=$1 [L] 
+1

添加重写规则,你可能缺少[QSA] ,但这只是一个猜测,因为没有代码。 – Dexa

+1

我想要很多东西,但是你不愿意向我们展示你的重写规则吗? –

回答

2

您可以使用QSA标志查询字符串添加到您的转发页面

RewriteRule ^staff/(new|edit|delete)$ /staff.php?action=$1 [L,QSA] 
+0

好吧,但如果有人输入'/ staff/new&a = b'会怎么样?我会得到'500内部服务器错误' –

+0

你为什么要这样做?它会被转发到'/staff.php?action = new&a = b'。无论如何,出于安全原因,你总是应该检查你的GET参数。在这种情况下是否只有'error'参数可以添加到查询字符串中?如果是,那么可以添加一个条件来匹配这种可能性 –

相关问题