Ответы:
Вам нужна parse_str
функция, и вам нужно установить второй параметр, чтобы данные помещались в массив, а не в отдельные переменные.
$get_string = "pg_id=2&parent_id=2&document&video";
parse_str($get_string, $get_array);
print_r($get_array);
?key=lorem&key=ipsum
как если бы вы key=ipsum
указали только строку запроса в URL. И я считаю недопустимым повторное использование ключа и ожидание последовательных результатов или сохранение всех экземпляров ключа. Действительный подход, по крайней мере для строки запроса, отправленной в PHP, будет таким ?key[]=lorem&key[]=ipsum
, поэтому ваш доморощенный подход может искать любые случаи, &{x}=
когда x встречается более одного раза, и заменять на x[]
(и трактовать? Так же, как &)
?key[]=lorem&key[]=ipsum
несколько недель назад. Но спасибо, что поделились ссылкой!
Иногда parse_str()
только примечание является точным, оно может отображаться, например:
$url = "somepage?id=123&lang=gr&size=300";
parse_str () вернет:
Array (
[somepage?id] => 123
[lang] => gr
[size] => 300
)
Было бы лучше сочетать parse_str()
с parse_url()
так:
$url = "somepage?id=123&lang=gr&size=300";
parse_str( parse_url( $url, PHP_URL_QUERY), $array );
print_r( $array );
$_SERVER['QUERY_STRING']
Использование parse_str()
.
$str = 'pg_id=2&parent_id=2&document&video';
parse_str($str, $arr);
print_r($arr);
Используйте http://us1.php.net/parse_str
Внимание, это использование:
parse_str($str, &$array);
не
$array = parse_str($str);
Если у вас возникли проблемы с преобразованием строки запроса в массив из-за закодированных амперсандов
&
тогда обязательно используйте html_entity_decode
Пример:
// Input string //
$input = 'pg_id=2&parent_id=2&document&video';
// Parse //
parse_str(html_entity_decode($input), $out);
// Output of $out //
array(
'pg_id' => 2,
'parent_id' => 2,
'document' => ,
'video' =>
)
Есть несколько возможных способов, но для вас уже есть встроенная parse_str
функция
$array = array();
parse_str($string, $array);
var_dump($array);
Это код PHP для разделения запроса в mysql & mssql
enter code here
function splitquery($strquery)
{
$arrquery=explode('select',$strquery);
$stry='';$strx='';
for($i=0;$i<count($arrquery);$i++)
{
if($i==1)
{
echo 'select '.trim($arrquery[$i]);
}
elseif($i>1)
{
$strx=trim($arrquery[($i-1)]);
if(trim(substr($strx,-1))!='(')
{
$stry=$stry.'
select '.trim($arrquery[$i]);
}
else
{
$stry=$stry.trim('select '.trim($arrquery[$i]));
}
$strx='';
}
}
return $stry;
}
Пример:
выберите xx из xx выберите xx, (выберите xx) из xx, где y = 'cc' выберите xx из xx, оставьте соединение (выберите xx), где (выберите топ 1 xxx из xxx) oder по xxx desc ";
выберите хх из хх
выберите xx, (выберите xx) из xx, где y = 'cc'
выберите хх из хх левого соединения (выберите хх), где (выберите топ 1 ххх из ххх) или от ххх
Спасибо, из Индонезии Sentrapedagang.com
Для этого конкретного вопроса выбранный ответ является правильным, но если в URL-адресе есть избыточный параметр - например, дополнительное «е» - функция молча завершится сбоем без появления ошибки или исключения:
a=2&b=2&c=5&d=4&e=1&e=2&e=3
Поэтому я предпочитаю использовать свой собственный парсер, например:
//$_SERVER['QUERY_STRING'] = `a=2&b=2&c=5&d=4&e=100&e=200&e=300`
$url_qry_str = explode('&', $_SERVER['QUERY_STRING']);
//arrays that will hold the values from the url
$a_arr = $b_arr = $c_arr = $d_arr = $e_arr = array();
foreach( $url_qry_str as $param )
{
$var = explode('=', $param, 2);
if($var[0]=="a") $a_arr[]=$var[1];
if($var[0]=="b") $b_arr[]=$var[1];
if($var[0]=="c") $c_arr[]=$var[1];
if($var[0]=="d") $d_arr[]=$var[1];
if($var[0]=="e") $e_arr[]=$var[1];
}
var_dump($e_arr);
// will return :
//array(3) { [0]=> string(1) "100" [1]=> string(1) "200" [2]=> string(1) "300" }
Теперь у вас есть все вхождения каждого параметра в своем собственном массиве, вы всегда можете объединить их в один массив, если хотите.
Надеюсь, это поможет!
?key=lorem&key=ipsum
что в результатеarray(["key"]=>"ipsum")
возникает вопрос, есть ли функция для получения s.th. как этоarray(["key"]=>array("lorem", "ipsum"))
или я должен создать эту функцию самостоятельно?