【问题标题】:.htaccess how to rewrite rule for multi .php files.htaccess 如何重写多个 .php 文件的规则
【发布时间】:2019-02-19 19:26:41
【问题描述】:

我现在正在使用下一个 .htaccess:

RewriteEngine On
RewriteRule ^(.*)$ page1.php?$1 [QSA]

page1 可以正常工作,但page2 不能正常工作

请问我怎样才能让它工作?

我试过了:

RewriteRule ^(.*)$ $1.php?$2 [QSA]

对于文件夹中的每个 php 文件,但它不起作用。

【问题讨论】:

    标签: php regex .htaccess


    【解决方案1】:

    我想说这就是您要立即寻找的东西:

    RewriteEngine On
    RewriteRule ^/?page1/(.*)$ /page1.php?$1 [END]
    RewriteRule ^/?page2/(.*)$ /page2.php?$1 [END]
    

    但可能值得检查这是否不能推广到任意“页面”:

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

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

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

    一般来说:您应该始终喜欢将此类规则放在 http 服务器主机配置中,而不是使用动态配置文件(“.htaccess”)。这些动态配置文件增加了复杂性,通常是导致意外行为的原因,难以调试,而且它们确实减慢了 http 服务器的速度。它们仅在您无法访问真正的 http 服务器主机配置(阅读:非常便宜的服务提供商)或坚持编写自己的规则的应用程序(这是一个明显的安全噩梦)的情况下作为最后一个选项提供。

    【讨论】:

    • 非常感谢,是的,它在没有状态 500 的情况下工作
    猜你喜欢
    • 2017-07-26
    • 2014-04-23
    • 2019-03-19
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2015-02-15
    • 2017-11-21
    • 2013-06-29
    相关资源
    最近更新 更多