jbonnett Posted August 8, 2015 Share Posted August 8, 2015 Hey all, My URL is being sent as http://localhost/videos/On%20the%20go although if I use rawurldecode("On%20the%20go") I get "Onthego" rather than "On the go"... Any ideas? This should work, I've also tried urldecode() as it's a similar method but had no luck. Quote Link to comment https://forums.phpfreaks.com/topic/297686-rawurldecode-not-decoding-20-as-white-space/ Share on other sites More sharing options...
scootstah Posted August 8, 2015 Share Posted August 8, 2015 How are you retrieving that URI? Can we see some actual code? echo rawurldecode("On%20the%20go"); running this produces "On the go" as expected, for me anyway. Quote Link to comment https://forums.phpfreaks.com/topic/297686-rawurldecode-not-decoding-20-as-white-space/#findComment-1518246 Share on other sites More sharing options...
jbonnett Posted August 8, 2015 Author Share Posted August 8, 2015 (edited) How are you retrieving that URI? Can we see some actual code? echo rawurldecode("On%20the%20go"); running this produces "On the go" as expected, for me anyway. If I don't encode the URL or decode it e.g. keep the white space in the URL, it works fine. I'm have my own MVC, I'm retrieving the URI via $_GET request forwarded to a function using call_user_func_array(), so I then do something like this: some_function($get = "") { if($get != "") { echo rawurldecode($get); } } Edited August 8, 2015 by jbonnett Quote Link to comment https://forums.phpfreaks.com/topic/297686-rawurldecode-not-decoding-20-as-white-space/#findComment-1518247 Share on other sites More sharing options...
jbonnett Posted August 8, 2015 Author Share Posted August 8, 2015 Nevermind I found the problem: private function parseURL() { if(isset($_GET["url"])) { return explode("/", filter_var(rtrim($_GET["url"], "/"), FILTER_SANITIZE_URL)); } } I fixed it by: private function parseURL() { if(isset($_GET["url"])) { return explode("/", str_replace('\/', ' ', filter_var(rtrim(str_replace(' ', '\/', $_GET["url"]), "/"), FILTER_SANITIZE_URL))); } } Do you have any ideas to make this better? Maybe a different character to make the spaces? Quote Link to comment https://forums.phpfreaks.com/topic/297686-rawurldecode-not-decoding-20-as-white-space/#findComment-1518248 Share on other sites More sharing options...
scootstah Posted August 8, 2015 Share Posted August 8, 2015 When you call $_GET['url'], PHP automatically decodes it. So when you run it through filter_var(), the string has a space in it which is an illegal character, and is thus removed. I've played with it for a bit and I can't see a real clean way to do what you want. I came up with this: (warning - I'm very tired right now. This could be terrible) $parts = explode("/", trim($_GET['url'], "/")); $parts = array_map(function($part){ return urldecode(filter_var(urlencode($part), FILTER_SANITIZE_URL)); }, $parts);This will break up your parameter without sanitizing it, and then it will iterate over each part and do the following: urlencode (to convert the decoded spaces back to +), filter_var (to remove illegal characters), urldecode (to convert any encoded characters back again). Pretty hacky. The way I would do it though, is to just not use filter_var. I would just use regex to replace illegal characters, since there is a whole bunch of characters allowed in FILTER_SANITIZE_URL that really don't need to be in a URL. 1 Quote Link to comment https://forums.phpfreaks.com/topic/297686-rawurldecode-not-decoding-20-as-white-space/#findComment-1518251 Share on other sites More sharing options...
Recommended Posts
Join the conversation
You can post now and register later. If you have an account, sign in now to post with your account.