Warning: file_get_contents(/data/phpspider/zhask/data//catemap/1/php/256.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Php htaccess重写规则在joomla 2.5中不起作用_Php_.htaccess_Mod Rewrite_Joomla_Joomla2.5 - Fatal编程技术网

Php htaccess重写规则在joomla 2.5中不起作用

Php htaccess重写规则在joomla 2.5中不起作用,php,.htaccess,mod-rewrite,joomla,joomla2.5,Php,.htaccess,Mod Rewrite,Joomla,Joomla2.5,在joomla项目中,我的页面中有一个类似“localhost/joomla/ezlinks part info?brand=xyz&partid=MOT:D44-488JK”的页面,用于定制php代码。在该页面中,我包含了一些外部功能的.php文件 现在我想显示类似“localhost/joomla/xyz/MOT:D44-488JK.html”的url 为了得到这个,我在joomla htaccess中使用了下面的重写规则 重写规则^([A-Za-z]+)/([A-Za-z0-9:-]+).

在joomla项目中,我的页面中有一个类似“localhost/joomla/ezlinks part info?brand=xyz&partid=MOT:D44-488JK”的页面,用于定制php代码。在该页面中,我包含了一些外部功能的.php文件

现在我想显示类似“localhost/joomla/xyz/MOT:D44-488JK.html”的url

为了得到这个,我在joomla htaccess中使用了下面的重写规则

重写规则^([A-Za-z]+)/([A-Za-z0-9:-]+).html$ezlinks零件信息?品牌=$1,零件=$2[L,QSA]

但404错误显示在此页面中。如果我在核心php htacces中使用这个规则,它就可以正常工作

有谁能给我指点一下,我能做些什么使它起作用呢

提前谢谢

.htacces

    ##
# @package      Joomla
# @copyright    Copyright (C) 2005 - 2014 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]
#
RewriteRule ^([A-Za-z]+)/([A-Za-z0-9:-]+)\.html$ ezlinks-part-info?brand=$1&partid=$2 [L,QSA]
## End - Joomla! core SEF Section.
##
#@Joomla
#@copyright版权所有(C)2005-2014开源事宜。版权所有。
#@license GNU通用公共许可证版本2或更高版本;请参阅LICENSE.txt
##
##
#如果您选择使用此文件,请完整阅读此文件!
#
#此部分下方的行:“选项+FollowSymLinks”可能会导致问题
#使用一些服务器配置。使用mod_rewrite时需要它,但可能已经存在
#由服务器管理员以允许在中更改的方式进行设置
#您的.htaccess文件。如果使用它导致服务器出错,请将其注释掉(添加到
#行的开头),在浏览器中重新加载站点并测试sef url。如果有效的话,
#它已由服务器管理员设置,您不需要在此处设置。
##
##如果导致错误,可以注释掉,请参见上面的注释。
选项+FollowSymLinks
##Mod_正在使用中重写。
重新启动发动机
##开始-重写规则以阻止一些常见的漏洞攻击。
#如果您的网站出现问题,请排除下面列出的操作
#这将试图阻止对Joomla的最常见类型的利用“尝试”!
#
#阻止任何试图在URL中对数据进行base64_编码的脚本。
RewriteCond%{QUERY\u STRING}base64\u encode[^(]*\([^)]*\)[或]
#阻止在URL中包含标记的任何脚本。
重写cond%{QUERY_STRING}(|%3E)[NC,或]
#阻止任何试图通过URL设置PHP全局变量的脚本。
重写条件%{QUERY\u STRING}全局(|\[|\%[0-9A-Z]{0,2})[或]
#阻止任何试图通过URL修改_请求变量的脚本。
重写条件%{QUERY\u STRING}\u请求(|\[|\%[0-9A-Z]{0,2})
#返回403禁止标题并显示根主页的内容
重写规则。*index.php[F]
#
##结束-重写规则以阻止一些常见的漏洞攻击。
##开始-自定义重定向
#
#如果需要重定向某些页面,或将规范非www设置为
#www重定向(反之亦然),将代码放在这里
#重定向使用正确的重写规则语法和[R=301,L]标志。
#
##结束-自定义重定向
##
#如果您的Web服务器的URL
#与物理文件路径没有直接关系。
#更新您的Joomla!目录(仅适用于根目录)。
##
#重写基/
##开始-Joomla!核心SEF部分。
#
重写规则。*-[E=HTTP\U授权:%{HTTP:AUTHORIZATION}]
#
#如果请求的路径和文件不是/index.php,则
#尚未在内部重写为index.php脚本
重写cond%{REQUEST_URI}!^/index\.php
#请求的是组件文件夹中的内容,
#或用于站点根目录,或用于无扩展URL,或
#请求的URL以列出的扩展名之一结尾
重写cond%{REQUEST_URI}/component/|(/[^.]*|\(php | html |提要| pdf | vcf |原始))$[NC]
#请求的路径和文件与物理文件不直接匹配
重写cond%{REQUEST_FILENAME}!-f
#请求的路径和文件与物理文件夹不直接匹配
重写cond%{REQUEST_FILENAME}!-d
#在内部将请求重写为index.php脚本
重写规则。*index.php[L]
#
重写规则^([A-Za-z]+)/([A-Za-z0-9:-]+)\.html$ezlinks零件信息?品牌=$1,零件=$2[L,QSA]
##结束-Joomla!核心SEF部分。

mod\u rewrite是否正常工作?在
中放入一些垃圾时,是否会出现500个内部服务器错误。htaccess
?还将粘贴完整的
内容。htaccess
内容。是,会出现500个内部服务器错误。并将.htacces内容粘贴到上面。请在
RewriteRule.-[E=HTTP\u授权:%{HTTP:Authorization}]
是的,按照您所说的移动了我的重写规则,但不起作用。删除
L
标志,这样它将首先将其重写到
ezlinks-part-info?brand=xyz&partid=MOT:D44-488JK
,然后它将被下一个规则匹配并重写到
index.php
。它应该可以工作。