From 6ab7452ae689b0089dce8b9ea9619cc60f29d7c0 Mon Sep 17 00:00:00 2001 From: jimjshields Date: Thu, 5 Feb 2015 16:08:03 -0500 Subject: [PATCH] Added better parsing for GET and POST queries. --- tiny.py | 39 ++++++++++++++++++++++++++------------- 1 file changed, 26 insertions(+), 13 deletions(-) diff --git a/tiny.py b/tiny.py index bc75af2..117ab36 100644 --- a/tiny.py +++ b/tiny.py @@ -49,19 +49,19 @@ def request_handler(environ, start_response): # FIX: Parse queries more cleanly. if query_string != '': - queries = [query.split('=') for query in query_string.split('&')] - queries = {q[0]: q[1] for q in queries} + queries_data = [query.split('=') for query in query_string.split('&')] + queries_data = {q[0]: q[1] for q in queries_data} else: - queries = None + queries_data = None - # FIX: Figure out how to deal w/ POST requests and parse their data. - if content_length: - content = environ.get('wsgi.input').read(int(content_length)) - print content + # FIX: Parse POST requests more cleanly. + post_data = None + form = cgi.FieldStorage(fp=environ.get('wsgi.input'), environ=environ) if method == 'POST': - form = cgi.FieldStorage() - print form.getvalue('name') + post_data = {key: form.getvalue(key) for key in form.keys()} + elif method == 'GET': + queries_data = {key: form.getvalue(key) for key in form.keys()} # URL Routing if path not in URLS: @@ -87,7 +87,10 @@ def request_handler(environ, start_response): # This sends the response headers to the server, which sends to the client. start_response(status, headers) - content = [URLS[path](environ)] + if post_data: + content = [URLS[path](environ, post_data)] + else: + content = [URLS[path](environ, queries_data)] return content # TODO: Response @@ -96,14 +99,24 @@ def request_handler(environ, start_response): # TODO: Routing -def user(environ): - return 'Here\'s the user trying to access: %s' % (environ.get('USER', '')) +def user(environ, post_data='', queries_data=''): + html = '
' + html += '
' + html += '
' + html += '
' + return (html + + 'Here\'s the user trying to access: %s'\ + 'and here\'s what they got: %s' % (environ.get('USER', ''), queries_data)) def index(environ): return 'Home' def jim(environ): - return '
' + html = '
' + html += '
' + html += '
' + html += '
' + return html # URLS