假设我的访客到达:
mydomain.com/nice-url/?p1=a&p2=b
我希望他们被重定向到:
mydomain.com/nice-url/?p1=a
(可能与header("Location:)
所以我想把绳子剥掉p2=b。
由于这只是一个示例,可能还有许多其他参数,因此我正在寻找最明智的解决方案,包括以下方法:
p2。p1还要记住,这nice-url也可以是各种不同的事情,例如:
name-number-one,name-number-two, ETC。
另外,我不寻找.htaccess解决方案,因为我想将剥离参数的值存储在会话中。
按照建议,您可以使用parse_url(文档)。这是比 hanshenrik 发布的更通用的方法。它使用文档unparse_url注释中发现的稍微修改的(该行被修剪)和一些正则表达式:$query&
<?
function unparse_url($parsed_url) {
$scheme = isset($parsed_url['scheme']) ? $parsed_url['scheme'] . '://' : '';
$host = isset($parsed_url['host']) ? $parsed_url['host'] : '';
$port = isset($parsed_url['port']) ? ':' . $parsed_url['port'] : '';
$user = isset($parsed_url['user']) ? $parsed_url['user'] : '';
$pass = isset($parsed_url['pass']) ? ':' . $parsed_url['pass'] : '';
$pass = ($user || $pass) ? "$pass@" : '';
$path = isset($parsed_url['path']) ? $parsed_url['path'] : '';
$query = isset($parsed_url['query']) ? '?' . trim($parsed_url['query'], '&') : '';
$fragment = isset($parsed_url['fragment']) ? '#' . $parsed_url['fragment'] : '';
return "$scheme$user$pass$host$port$path$query$fragment";
}
function strip_query($url, $query_to_strip) {
$parsed = parse_url($url);
$parsed['query'] = preg_replace('/(^|&)'.$query_to_strip.'[^&]*/', '', $parsed['query']);
return unparse_url($parsed);
}
function keep_only_query($url, $query_to_keep) {
$parsed = parse_url($url);
$parsed['query'] = preg_replace('/(^|&)(?!'.$query_to_keep.')[^&]*/', '', $parsed['query']);
return unparse_url($parsed);
}
$url = 'mydomain.com/nice-url/?p1=a&p2=b';
# or for request url
# $url = "http://$_SERVER[HTTP_HOST]$_SERVER[REQUEST_URI]";
# "Strip anything that starts with p2"
var_dump(strip_query($url, 'p2'));
# --> string(27) "mydomain.com/nice-url/?p1=a"
# "Strip anything that doesn't start with p1"
var_dump(keep_only_query($url, 'p1'));
# --> string(27) "mydomain.com/nice-url/?p1=a"
# redirect
$new_url = strip_query($url, 'p2')); # or whatever query you want to strip/keep
header("Location: $new_url");
Run Code Online (Sandbox Code Playgroud)
我希望正keep_only_query则表达式是完整的并且适用于您遇到的所有网址,但这是我的第一次尝试。
也许正则表达式太过分了(没有做任何基准测试),所以这里是两个函数的版本,没有正则表达式,但有parse_strand http_build_query(如 hanshendrik 提议的)。
function strip_query($url, $query_to_strip) {
$parsed = parse_url($url);
parse_str($parsed['query'], $query);
unset($query[$query_to_strip]);
$parsed['query'] = http_build_query($query);
return unparse_url($parsed);
}
function keep_only_query($url, $query_to_keep) {
$parsed = parse_url($url);
parse_str($parsed['query'], $query);
foreach($query as $query_key => $query_val) {
if($query_key != $query_to_keep) unset($query[$query_key]);
}
$parsed['query'] = http_build_query($query);
return unparse_url($parsed);
}
Run Code Online (Sandbox Code Playgroud)
注意:与正则表达式版本相反,它仅适用于名称完全相同的p1参数(例如, p2),而正则表达式版本适用于以名称开头的名称(例如p1=..., p2=...,但也适用于p1something=..., p2_whatever=...)。不知道这是否是问题措辞的意图,但这就是我首先的理解:
- 删除所有以...开头的内容
当然,底部版本也可以扩展为比较查询键的开头......使用正则表达式;-)(或substr)
最后是一个没有任何奇怪的正则表达式但带有 的版本substr,按照 OP 的预期检查键的开头。
function strip_query($url, $query_to_strip) {
$len = strlen($query_to_strip);
$parsed = parse_url($url);
parse_str($parsed['query'], $query);
foreach($query as $query_key => $query_val) {
if(substr($query_key, 0, $len) == $query_to_strip) unset($query[$query_key]);
}
$parsed['query'] = http_build_query($query);
return unparse_url($parsed);
}
function keep_only_query($url, $query_to_keep) {
$len = strlen($query_to_keep);
$parsed = parse_url($url);
parse_str($parsed['query'], $query);
foreach($query as $query_key => $query_val) {
if(substr($query_key, 0, $len) != $query_to_keep) unset($query[$query_key]);
}
$parsed['query'] = http_build_query($query);
return unparse_url($parsed);
}
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
5365 次 |
| 最近记录: |