【问题标题】:Rewrite rule not working - Redirect to new url重写规则不起作用 - 重定向到新网址
【发布时间】:2019-05-04 05:03:08
【问题描述】:

我们搬到了新的cms,有一些链接需要从旧的url重定向到新的,写了revrite规则,但是什么都不起作用

旧网址 - site.com/1222_titlepost.html 新网址 - site.com/blog/{slug} - id

RewriteRule ^post/([0-9]{1,})_([0-9a-z]{1,}).html blog/$1 [NC,R=301,L]

Centos 7 , apache2 , php7 , whm+cpanel

【问题讨论】:

  • 我怀疑新 URL 是否真的应该包含 blancs... 您能否提供两个旧 URL 和新 URL 的 真实 示例?谢谢。
  • 旧随机网址 - site.com/post/194_myfirst_post.html 新网址 - site.com/blog/194

标签: .htaccess mod-rewrite


【解决方案1】:

您在问题评论中提供的示例与您在问题中声明的内容匹配。如果 that 真的表达了实际的任务,那么你的问题的答案就很简单了:

RewriteEngine on
RewriteRule ^/?post/(\d+)_ /blog/$1 [R=301]

最好先从 302 临时重定向开始,稍后再将其更改为 301 永久重定向,前提是您确定一切都已正确设置。这样可以防止在尝试时出现缓存问题...

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

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

【讨论】:

  • 这是我的 htacess IndexIgnore * Options -Indexes #Options +FollowSymLinks RewriteEngine On RewriteRule ^/?post/(\d+)_ /blog/$1 [R=301] RewriteCond %{REQUEST_FILENAME} !-d RewriteCond %{REQUEST_FILENAME} !-f RewriteRule ^ index.php [L]
  • 您是否确保您的 http 服务器考虑并解释了动态配置文件完全?你是怎么做到的?而“不工作”是什么意思 exactly ?您的 http 服务器错误日志文件显示了什么?
猜你喜欢
  • 1970-01-01
  • 1970-01-01
  • 2016-03-14
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2015-08-10
  • 2017-02-13
  • 1970-01-01
相关资源
最近更新 更多