PHP Function: Remove a Query String Key=>Value
I was recently coding a website which relied heavily on query string variables. It was absolutely imperative that I keep the query string clean and not duplicate keys. I needed to find a PHP function that would allow me to remove keys (and their values) easily and reliably. Enter a PHP function I found at Added Bytes:
/* the function */
function remove_querystring_var($url, $key) {
$url = preg_replace('/(.*)(?|&)' . $key . '=[^&]+?(&)(.*)/i', '$1$2$4', $url . '&');
$url = substr($url, 0, -1);
return $url;
}
/* usage */
//pretending this page is
All I needed to do was provide the URL (in my case I wanted the current page's URI) and the key to remove -- so simple!
All credit goes to Added Bytes for their awesome work. It saved me a lot of time...hopefully it does for you too!
It's no secret that Facebook has become a major traffic driver for all types of websites. Nowadays even large corporations steer consumers toward their Facebook pages instead of the corporate websites directly. And of course there are Facebook "Like" and "Recommend" widgets on every website. One...
Sooner or later you'll run across a regular expression. With their cryptic syntax, confusing documentation and massive learning curve, most developers settle for copying and pasting them from StackOverflow and hoping they work. But what if you could decode regular expressions and harness their power? In...
I work with an awesome cast of developers at Mozilla, and one of them in Daniel Buchner. Daniel's shared with me an awesome strategy for detecting when nodes have been injected into a parent node without using the deprecated DOM Events API.
Before each of the browser vendors we like was providing unique CSS controls, Internet Explorer was setting the tone. One such example is IE's early implementation of CSS filters. Internet Explorer was also the first browser that allowed developers to, for better or worse, customize...
I needed something like this also in a project.
This is what I came up with
Not sure what’s the performance difference though
I have a very similar function to yours, David, and it seems for nearly the same reason.
I would use preg_quote() on the key…
When do you need to remove a key from a query string? Just curious, since I never needed to and been using php quite long.
@Phil Pérusse:
I think unset will be much faster than array_diff if you’re only removing a few keys.
Hi,
I use a similar function sometimes – but it does more than just remove a certain key. The purpose of the function is to build the querystring entirely. It takes two parameters, one array containing keys (with values) that should be added to the querystring and one array containing keys that should be removed. Then it cycles through the current querystring and removes or keeps keys depending on the parameter and finally adds keys if there are any.
Maybe this approach isn’t as good in your case but I’ve found it to be quite useful when I have a site that’s depending on querystring entirely.
// trippo
the function don’t works if I want to remove first key of my query string
$query_string = “page=home&lang=it”;
echo remove_querystring_var($query_string,’page’); //not works
echo remove_querystring_var($query_string,’lang’); //works
Did you get any solution for this ?
Same problem. Dadiv’s function is not totally prepared to be use only with a QueryString as parameter. In that case you have to change this line:
thanks, that’s cool :)
Hi,
nice code, but it did not work for the first parameter, because the “?” should be escaped: “\?” to match.
See here: http://php.net/manual/de/function.preg-replace.php
if i add escape it works for me:
Still that entire regex could be reduced to:
I like the parse_str/http_query_build idea so I extended it to include the ability to remove an array of values and add an array of values.
Example:
Current URL = http://www.example.com?one=1&two=2&three=3&four=4
@Dustin Hansen: Dustin’s solution is the most elegant and I found the other solutions to have issues with parameter’s at the beginning and end of the query string – in my testing Dustin’s solution worked for parameters at all positions.
@Adam: Oh and just for making it even more condensed, shorten the whole function to this:
function remove_qs_key($url, $key) {
return preg_replace(‘/(?:&|(\?))’ . $key . ‘=[^&]*(?(1)&|)?/i’, “$1”, $url);
}
I had an array of checkbox values being passed in the querystring, and I don’t think these functions work for removing it.
I found it easier to just directly define the
$_SERVER['QUERY_STRING']
by concatenating the$_GET[]
variables I wanted to pass, and leaving out the ones I didn’t (the checkbox array)thanks!! lots of cool ways.
I always like a regular expression but an alternative would be to use the ? as a delimiter and explode the uri into an array and retrieve the first result i.e
I took the regex and expanded it. PHP allows array references in the querystring vars such as http://www.example.com/?a%5B%5D=1&a%5B0%5D=3&a%5B5%5D%5B7%5D%5B89%5D%5Bfdds%5D%5Bddd%5D=44
Also, this function allows the removal of multiple vars.
echo htmlentities(getRedirectURL("http://www.example.com/?a[]=1&a[0]=3&a[5][7][89][fdds][ddd]=44","a"));
echo htmlentities(getRedirectURL("http://www.example.com/?a=1&a=2&b=3&c=4",array("a","c")));
function getRedirectURL($url,$keysToRemove) {
if (!is_array($keysToRemove))
$keysToRemove = array($keysToRemove);
foreach ($keysToRemove as $key)
$url = preg_replace('/(?:&|(\\?|\\G))' . urlencode($key) . '(?:\\[[^]]*\\])*=[^&]*(?(1)&|)?/i', "$1", $url);
if (substr($url,-1) == '?')
$url = substr($url,0,-1);
return $url;
}
RegEx are Tough to understand… But they solve our problems in short…
I Use array in such Tasks.
what will be regex, if i want to remove any key from querystring [only] like,
tab=basic&action=update&tid=57969
want to delete key like, tab so the result will be ,
action=update&tid=57969
Above issue is solved by following,
return preg_replace(‘/’.$key.’=[^&]+?(&)(.*)/i’, ‘$2’, $url);
But,
It’s not working for removing last param from url or string, can anyone help for this !!!!
I have two warnings for readers stumble across this article:
1) Many of the code examples above gave syntax errors when I copied and pasted the code. The syntax errors are caused by this webpage printing a single quotation mark as some other type of symbol that looks similar to a quote mark but is actually not. To solve this, just replace those fake single quote marks with the real thing from your keyboard.
2) None of the code samples that I tried above worked on the first query parameter in the query string. Even the code samples that say they have this fixed still doesn’t work. (I was getting my Query string from the Server variable. Those who use a full URL might have different results). I believe this is the case because all these code samples look for a ‘&’ symbol to separate query terms. Obviously the first query term will never start with a & symbol.
Adam’s example helped me to resolve a string building issue I was having with pagination of a search facility.
Beware of the quotes in the examples provided as mentioned by Paul R, many of the examples i tested above required further modification, due to this website’s output.
I recommend using parse_str (if you don’t just use $_GET directly) plus http_build_query. It’s cleaner and closer related to what you really want to do: it’s not the string you care for, it’s the parameters.
Don’t worry about what solution is the most efficient; that’s microoptimization. The difference is very small compared to the whole request time.
Once the parameter is stripped out, don’t forget to trim any trailing “?” characters from the end. If the parameter being stripped is the only parameter, then a “?” will be left behind, all on its own.
Thanks, David! This helped a lot on an API I was working on.
Basically, I needed to send an email to myself with the parameters used whenever an error was encountered. Everything was okay, but the server was adding a few of its own parameters to the $_GET variable. I was able to strip it clean with this.
Thanks again.
function requette_url_remove($url, $key) {
parse_str($url, $result_array);
unset($result_array[$key]);
$url = http_build_query($result_array);
return $url;
}
Like that solution faisal. Full url solution
Kind of the opposite of the article, but you could create allowed array from
array_keys(parse_str)
and unset the keys you want removed, or modify with a new arg and conditional so it can include or excludeGreat article. Another thing to note is that only faisal and seyi’s implementation will remove multiple instances of the given key in the query string. You’ve probably got worse problems if you’ve got multiple keys repeated on the same query string, but a nice feature all the same.
Thanks, very useful.
Hello David
not much but , sorry, slightly off topic
why and when it comes the time to use these functions
– http_build_query
– parse_url
– parse_str
thank you for hinting