.htaccess如何删除扩展名+更改符号的问题



我有这个:

website/test.php?id=1

如何得到这个?

website/test/1

我用它来删除.php扩展。我尝试了一些规则来获得所需的结果,但我做不到。

RewriteEngine On
RewriteCond %{REQUEST_FILENAME}.php -f
RewriteRule !.*.php$ %{REQUEST_FILENAME}.php [QSA,L]

这应该会为您指明正确的方向:

RewriteEngine On
RewriteCond %{REQUEST_FILENAME}.php -f
RewriteRule !.*.php$ %{REQUEST_FILENAME}.php [END]
RewriteCond %{REQUEST_URI} ^/([^/]+)/(d+)/?$
RewriteCond %1.php -f
RewriteRule ^ /%1.php?id=%2 [END]

它检查请求的URL的路径组件,查看是否存在类似于现有重写规则的相应php脚本,如果存在,则执行实际的内部重写。

如果您使用上面的规则收到内部服务器错误(http状态500(,那么很可能您操作的是非常旧版本的apachehttp服务器。在这种情况下,您将在http服务器错误日志文件中看到一个不受支持的[END]标志的明确提示。您可以尝试升级或使用旧的[L]标志,在这种情况下,它可能也会起作用,尽管这在一定程度上取决于您的设置。

此实现将在http服务器主机配置或动态配置文件(".htaccess"文件(中同样工作。显然,重写模块需要加载在http服务器内部,并在http主机中启用。如果使用动态配置文件,则需要注意在主机配置中完全启用了它的解释,并且它位于主机的DOCUMENT_ROOT文件夹中。

还有一句话:你应该总是更喜欢在http服务器主机配置中放置这样的规则,而不是使用动态配置文件(".htaccess"(。这些动态配置文件增加了复杂性,通常是导致意外行为的原因,很难调试,而且它们确实会减慢http服务器的速度。它们只是在您无法访问真正的http服务器主机配置(读作:非常便宜的服务提供商(或应用程序坚持编写自己的规则(这显然是一场安全噩梦(的情况下提供的最后一个选项。

最新更新