Zsh: extraire une requête CGI à un tableau associatif
Question
I ai une requête CGI comme suit:. 'A = 1 et b = 2 & c = 3'
Je souhaite extraire dans un tableau associatif tel que A $ A [a] = 1, $ A [b] = 2 et $ [c] = 3.
J'ai trouvé cette façon, mais je voudrais trouver un moyen plus simple (plus court) à ceci:
QUERY='a=1&b=2&c=3'
typeset -a T
T=( ${(s:&:)QUERY} )
typeset -A A
A=()
for v in $T; do
A+=( ${(s:=:)v} )
done
(bonus: trouver un moyen de gérer URL valeurs codées)
La solution
Pour les personnes intéressées, ce code parse GET et POST eux des paramètres et des magasins dans les QUERY_PARAMETERS de tableau global.
function parse_query_string()
{
local query="$1"
local -a pairs
pairs=( ${(s:&:)query} )
for v in $pairs; do
QUERY_PARAMETERS+=( ${(s:=:)v} ) # todo: handle parameters without =
done
for name in ${(k)QUERY_PARAMETERS}; do
local value="$QUERY_PARAMETERS[$name]"
QUERY_PARAMETERS[$name]="$(url_decode "$value")"
done
}
function url_decode()
{
setopt extendedglob
local d=${1//\%(#b)([0-F][0-F])/\\\x$match[1]}
d=${d//+/ }
echo "$d"
}
parse_query_string "$QUERY_STRING"
parse_query_string "$(cat)"
Licencié sous: CC-BY-SA avec attribution
Non affilié à StackOverflow