]> git.plutz.net Git - shcgi/commitdiff
parse get and post data automatically
authorpaul <paul@plutz.net>
Wed, 24 Feb 2016 20:15:37 +0000 (20:15 +0000)
committerpaul <paul@plutz.net>
Wed, 24 Feb 2016 20:15:37 +0000 (20:15 +0000)
svn path=/trunk/; revision=20

cgi.sh
index.cgi

diff --git a/cgi.sh b/cgi.sh
index 4f4cb509ed05458857209495f2d7d98e378dadbd..124496e0895ed11bce06279906cad9ed2c51c2b7 100755 (executable)
--- a/cgi.sh
+++ b/cgi.sh
@@ -24,17 +24,17 @@ declare -A _COOKIE
 
 [ -z "$HTTP_REFERER" ] && HTTP_REFERER="./"
 
-cgi_get() {  # parse HTTP GET string
-  debug "== CGI DATA: GET =="
-  printf '%s\n' "$QUERY_STRING" |tr '&' '\n' |while read query; do
-    key="$(printf %s "$query" |sed -r 's:^([a-zA-Z0-9_-]+)=(.*)$:\1:')"
-    val="$(printf %s "$query" |sed -r 's:^([a-zA-Z0-9_-]+)=(.*)$:\2:')"
-    _GET[$key]="$(printf "$(printf %s "$val" |sed 's:+: :g;s:\\:\\\\:g;s:%:\\x:g')")"
-    debug "_GET[$key] => $val"
-  done
-}
+# parse HTTP GET string
+debug "== CGI DATA: GET =="
+printf '%s\n' "$QUERY_STRING" |tr '&' '\n' |while read query; do
+  key="$(printf %s "$query" |sed -r 's:^([a-zA-Z0-9_-]+)=(.*)$:\1:')"
+  val="$(printf %s "$query" |sed -r 's:^([a-zA-Z0-9_-]+)=(.*)$:\2:')"
+  _GET[$key]="$(printf "$(printf %s "$val" |sed 's:+: :g;s:\\:\\\\:g;s:%:\\x:g')")"
+  debug "_GET[$key] => $val"
+done
 
-cgi_post() {  # parse HTTP POST string
+if [ "$REQUEST_METHOD" = POST ]; then
+  # parse HTTP POST string
   debug "== CGI DATA: POST =="
   sed -u 1q |tr '&' '\n' |while read query; do
     key="$(printf %s "$query" |sed -r 's:^([a-zA-Z0-9_-]+)=(.*)$:\1:')"
@@ -48,11 +48,11 @@ cgi_post() {  # parse HTTP POST string
     _POST[$key$n]="$value"
     debug "_POST[$key$n] => $value"
   done
-}
+fi
 
 cgi_refdata() { # Parse GET data from referer
   debug "== CGI DATA: REFERER =="
-  printf '%s\n' "$HTTP_REFERER" |cut -d'?' -f2- |tr '&' '\n' |while read query; do
+  printf '%s\n' "${HTTP_REFERER#*\?}" |tr '&' '\n' |while read query; do
     key="$(printf %s "$query" |sed -r 's:^([a-zA-Z0-9_-]+)=(.*)$:\1:')"
     val="$(printf %s "$query" |sed -r 's:^([a-zA-Z0-9_-]+)=(.*)$:\2:')"
     _REF[$key]="$(printf "$(printf %s "$val" |sed 's:+: :g;s:\\:\\\\:g;s:%:\\x:g')")"
index 61073454582d8d8a9212491dd4c221fa2ddaa3f3..b406bc9e827ff43b36e19bf6d7cd9a48efd01614 100755 (executable)
--- a/index.cgi
+++ b/index.cgi
@@ -34,7 +34,6 @@ _EXEC="${real%/shcgi/index.cgi}"  #execution directory
 [ -r "$_DATA/local.opts" ] && . "$_DATA/local.opts"
 
 . "$_EXEC/shcgi/cgi.sh"
-cgi_get
 
 [ -x "$_EXEC/globals.sh" ] && . "$_EXEC/globals.sh"