【问题标题】:Htaccess rewrite rule joomla 3Htaccess重写规则joomla 3
【发布时间】:2018-12-08 23:39:12
【问题描述】:

我想制定一个重写规则,将旧网址更改为新网址,如下所示:

https://www.website.com/apple/somethinghttps://www.website.com/orange/something

something-part 可以是任何东西,我只是想在所有带有苹果的链接中将“苹果”这个词换成“橙色”。

我有一个 joomla 3.8 网站,我在 joomla htaccess 文件中尝试了各种重写规则,但没有任何效果。我不知道如何编写规则以及将其放在 htaccess 文件中的什么位置。

最近失败: RewriteRule ^/apple(.*) /orange$1 [L,R=301]

我的 joomla htaccess 看起来像这样:

##
# @package      Joomla
# @copyright    Copyright (C) 2005 - 2013 Open Source Matters. All rights reserved.
# @license      GNU General Public License version 2 or later; see LICENSE.txt
##
##
# READ THIS COMPLETELY IF YOU CHOOSE TO USE THIS FILE!
#
# The line just below this section: 'Options +FollowSymLinks' may cause problems
# with some server configurations.  It is required for use of mod_rewrite, but may already
# be set by your server administrator in a way that dissallows changing it in
# your .htaccess file.  If using it causes your server to error out, comment it out (add # to
# beginning of line), reload your site in your browser and test your sef url's.  If they work,
# it has been set by your server administrator and you do not need it set here.
##
#Force IE out of compabilitymode
Header set X-UA-Compatible "IE=edge,chrome=1"
## Can be commented out if causes errors, see notes above.
Options +FollowSymLinks
## Mod_rewrite in use.
RewriteEngine On
## Begin - Rewrite rules to block out some common exploits.
# If you experience problems on your site block out the operations listed below
# This attempts to block the most common type of exploit `attempts` to Joomla!
#
# Block out any script trying to base64_encode data within the URL.
RewriteCond %{QUERY_STRING} base64_encode[^(]*\([^)]*\) [OR]
# Block out any script that includes a <script> tag in URL.
RewriteCond %{QUERY_STRING} (<|%3C)([^s]*s)+cript.*(>|%3E) [NC,OR]
# Block out any script trying to set a PHP GLOBALS variable via URL.
RewriteCond %{QUERY_STRING} GLOBALS(=|\[|\%[0-9A-Z]{0,2}) [OR]
# Block out any script trying to modify a _REQUEST variable via URL.
RewriteCond %{QUERY_STRING} _REQUEST(=|\[|\%[0-9A-Z]{0,2})
# Return 403 Forbidden header and show the content of the root homepage
RewriteRule .* index.php [F]
#
## End - Rewrite rules to block out some common exploits.
## Begin - Custom redirects
## End - Custom redirects
##
# Uncomment following line if your webserver's URL
# is not directly related to physical file paths.
# Update Your Joomla! Directory (just / for root).
##
# RewriteBase /
## Begin - Joomla! core SEF Section.
#
RewriteRule .* - [E=HTTP_AUTHORIZATION:%{HTTP:Authorization}]
#
# If the requested path and file is not /index.php and the request
# has not already been internally rewritten to the index.php script
RewriteCond %{REQUEST_URI} !^/index\.php
# and the request is for something within the component folder,
# or for the site root, or for an extensionless URL, or the
# requested URL ends with one of the listed extensions
RewriteCond %{REQUEST_URI} /component/|(/[^.]*|\.(php|html?|feed|pdf|vcf|raw))$ [NC]
# and the requested path and file doesn't directly match a physical file
RewriteCond %{REQUEST_FILENAME} !-f
# and the requested path and file doesn't directly match a physical folder
RewriteCond %{REQUEST_FILENAME} !-d
# internally rewrite the request to the index.php script
RewriteRule .* index.php [L]
#
## End - Joomla! core SEF Section.
#Redirect admin because of session error temporarely

【问题讨论】:

    标签: .htaccess url mod-rewrite joomla3.8


    【解决方案1】:

    您可以将以下内容添加到您的 .htaccess 文件中的 &lt;IfModule mod_rewrite.c&gt; 标签之间:试试这个

    RewriteCond %{HTTP_HOST}
    RewriteRule ^apple/(.*)$ /orange/$1 [R=301,L]
    

    【讨论】:

    • 它不工作,但我不确定我是否把它放在它应该放在的地方。
    • 添加了 htaccess。我应该把重写规则放在哪里?
    • 它在.htaccess里面,你可以放在任何地方。
    • 不知何故,上面的示例规则不起作用,所以我想我会仔细检查是否以某种方式把它放在错误的地方。
    【解决方案2】:

    我终于可以使用这条规则了:

    RewriteRule ^apple/(.*)$ /orange/$1 [R=301,NC,L]
    

    希望它能对其他人有所帮助;-)

    【讨论】: