2013-05-03 102 views
0

正在將一個自定義php網站轉移到Joomla的項目。將url後綴從.html更改爲.php joomla 2.5

我已經建立了結構,使新的網站將反映舊的網站,因此,例如:

oldsite.com/training/teaching-skills.php

新網站:

newsite.com/training/teaching-skills.html

我需要新的網站閱讀:

newsite.com/training/teaching-skills.php

我需要知道的是如何在啓用用戶友好的URL時保持.php擴展名。默認情況下的Joomla將增加的.html通過.htaccess文件,但我想保持/添加/名爲.php的

默認.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. 
## 
## 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 
# 
# If you need to redirect some pages, or set a canonical non-www to 
# www redirect (or vice versa), place that code here. Ensure those 
# redirects use the correct RewriteRule syntax and the [R=301,L] flags. 
# 
## 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. 

**

在這個任何意見將大大收到

親切的問候 艾倫

+0

有像sh404SEF這樣的joomla擴展。 – vishal 2013-05-03 10:36:55

+0

sh404SEF僅將.html添加到我所能看到的URL中。我需要的URL有.php – Alan 2013-05-03 12:08:34

回答

0

爲什麼不直接重定向所有.PHP網址爲t他新的html網址?

RewriteEngine on 
RewriteBase/

RewriteCond %{THE_REQUEST} (.*)\.php 
RewriteRule ^(.*)\.php $1.html [R=301,L] 
0

有些步驟對我很有幫助。

- >訪問包括> router.php

- >訪問的行號100並且改變

if ($format = $uri->getVar('format', 'html')) 

if ($format = $uri->getVar('format', 'php')) 

- >訪問的行號67和變化

$vars['format'] = $suffix; 

to

$path = str_replace('.'.$suffix,'' , $path); 
if ($suffix == 'php') { 
$vars['format'] = 'html'; 
} else { 
$vars['format'] = $suffix; 
}