Warning: file_get_contents(/data/phpspider/zhask/data//catemap/1/php/251.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的参数_Php_Regex_Apache_.htaccess_Mod Rewrite - Fatal编程技术网

Php 如何更改htaccess的参数

Php 如何更改htaccess的参数,php,regex,apache,.htaccess,mod-rewrite,Php,Regex,Apache,.htaccess,Mod Rewrite,我需要使用.httaces更改url参数,我对复杂的httaces不太熟悉,这就是为什么我需要这方面的帮助 http://www.gardeningwithangus.com.au/index.php?option=com_plant&view=plant&botanic-name=Wahlenbergia&Variar=Sky Mist&common name=Native Bluebell&plant id= 需要将工厂id更改为id。所以url将是类似的东西 index.php?optio

我需要使用.httaces更改url参数,我对复杂的httaces不太熟悉,这就是为什么我需要这方面的帮助

http://www.gardeningwithangus.com.au/index.php?option=com_plant&view=plant&botanic-name=Wahlenbergia&Variar=Sky Mist&common name=Native Bluebell&plant id=

需要将工厂id更改为id。所以url将是类似的东西
index.php?option=com\u plant&view=plant&植物学name=Wahlenbergia&Variar=Sky Mist&common name=Native Bluebell&id=

http://www.gardeningwithangus.com.au/plants?view=plant&botanic-name=Crowea+exalata&variar=Low+Dome&common name=Crowea&plant id=

有什么需要帮忙的吗

我的代码:

RewriteEngine On

RewriteCond %{QUERY_STRING} ^(view=plant)&plant-id=([0-9]*)(?:&|$) [NC]
RewriteRule ^(component/plant)/?$ /$1/?%1&id=%2 [L,NC,R=301]

##
# @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.
RewriteCond %{QUERY_STRING} ^(option=.+?)&plant-id=(.*)$ [NC]
RewriteRule ^(index\.php)$ $1?%1&id=%2 [L,NC,R=302]

RewriteCond %{QUERY_STRING} ^(view=.+?)&plant-id=(.*)$ [NC]
RewriteRule ^(plants)$ $1?%1&id=%2 [L,NC,R=302]
重新编写引擎打开
RewriteCond%{QUERY_STRING}^(视图=工厂)和工厂id=([0-9]*)(?:&|$)[NC]
重写规则^(组件/设备)/?$/$1/?%1&id=%2[L,NC,R=301]
##
#@Joomla
#@copyright版权所有(C)2005-2013开放源码事宜。版权所有。
#@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]
#
##结束-Joomla!核心SEF部分。
RewriteCond%{QUERY_STRING}^(选项=.+?)&工厂id=(.*)$[NC]
重写规则^(index\.php)$$1?%1&id=%2[L,NC,R=302]
RewriteCond%{QUERY_STRING}^(视图=.+?)&工厂id=(.*)$[NC]
重写规则^(工厂)$$1?%1&id=%2[L,NC,R=302]
假设查询参数的顺序与问题相同

通过
httpd.conf
(如果尚未启用)启用
mod_rewrite
.htaccess
,然后将此代码放入
文档根目录/htaccess
文件:

RewriteEngine On

RewriteCond %{QUERY_STRING} ^(option=.+?)&plant-id=(.*)$ [NC]
RewriteRule ^(index\.php)$ $1?%1&id=%2 [L,NC,R=302]

RewriteCond %{QUERY_STRING} ^(view=.+?)&plant-id=(.*)$ [NC]
RewriteRule ^(plants|component/plant)/?$ $1?%1&id=%2 [L,NC,R=302]
假设查询参数的顺序与问题相同

通过
httpd.conf
(如果尚未启用)启用
mod_rewrite
.htaccess
,然后将此代码放入
文档根目录/htaccess
文件:

RewriteEngine On

RewriteCond %{QUERY_STRING} ^(option=.+?)&plant-id=(.*)$ [NC]
RewriteRule ^(index\.php)$ $1?%1&id=%2 [L,NC,R=302]

RewriteCond %{QUERY_STRING} ^(view=.+?)&plant-id=(.*)$ [NC]
RewriteRule ^(plants|component/plant)/?$ $1?%1&id=%2 [L,NC,R=302]

似乎是mod_rewrite的工作。我不太了解,但这是一个开始。似乎是mod_rewrite的工作。我不太了解,但这是一个开始。第一个链接工作得很好,但第二个不工作!是的,但我需要像第一个一样,我刚刚测试了第二个链接,它变成了:/index.php?option=com_plant&view=plant&植物学name=Wahlenbergia&Variar=Sky Mist&common name=Native Bluebell&id=like删除单词plant-从Link2的最后一个链接变成:
/index.php?option=com_plant&view=plant&植物学name=Wahlenbergia&Variar=Sky%2520列表&common name=Native%2520 Bluebell&id=
植物id>转换为
id
第一个链接工作得很有魅力,bu第二个不起作用!是的,但我需要和第一个一样,我刚刚测试了第二个链接,它变成了:/index.php?option=com_plant&view=plant&植物学name=Wahlenbergia&Variar=Sky Mist&common name=Native Bluebell&id=like删除单词plant-从链接的最后一个链接变成:
/index.php?option=com_plant&view=plant&bootanic name=Wahlenbergia&RIVAR=Sky%2520列表和通用名称=本地%2520蓝莓和id=
转换
植物id
id