解析tornado查询参数:

  • self.request.query_arguments
  • self.get_query_argument[s](参数名称)

解析tornado的post参数:

  • self.request.body_arguments
  • self.get_body_argument[s](参数名称)

get,post解析参数都可:

  • self.get_argument[s](参数名称)

原始的post参数:

  • post_data = self.request.body.decode('utf-8')

headers参数:self.request.headers,对象(字典对象)

在项目中解析post参数时,发现以下问题:

request.body_arguments可以获取到form数据,但不能获取到curl过来的json数据
request.body.decode('utf-8')可以获取到所有的数据,但是是原始数据。
如果原始数据是curl过来json数据:直接json.loads(***)即可。
如果原始数据是form数据:直接json.loads(*)将抛出异常,因为数据格式是: username=abc%E5%8C%97%E4%BA%AC&email=&website=abc&language=%E4%B8%AD%E5%9B%BD

解决方法:

        post_data = self.request.body_arguments
post_data = {x: post_data.get(x)[0].decode("utf-8") for x in post_data.keys()}
if not post_data:
post_data = self.request.body.decode('utf-8')
post_data = simplejson.loads(post_data)

示例:

index.html

<!DOCTYPE html>
<html>
<head>
<title>sign in your name</title>
<link rel="icon" href="#" type="image/x-icon" />
<link rel="shortcut icon" href="#" type="image/x-icon" />
</head>
<body>
<h2>Please sing in.</h2>
<form method="post" action="/user">
<p>Name:<br><input type="text" name="username"></p>
<p>Email:<br><input type="text" name="email"></p>
<p>Website:<br><input type="text" name="website"></p>
<p>Language:<br><input type="text" name="language"></p>
<input type="submit" value="ok,submit my information">
</form>
</body>
</html>

user.html

<!DOCTYPE html>
<html>
<head>
<title>sign in your name</title>
<link rel="icon" href="#" type="image/x-icon" />
<link rel="shortcut icon" href="#" type="image/x-icon" />
</head>
<body>
<h2>Your Information</h2>
<p>Your name is {{username}}</p>
<p>Your email is {{email}}</p>
<p>Your website is {{website}}, it is very good. This website is make by {{language}}</p>
</body>
</html>

server.py

#!/usr/bin/env python
#coding:utf-8
import json
import tornado.web
import tornado.httpserver
import tornado.ioloop
import os
from tornado.options import define, options
define("port", default=9000, help="server port", type=int) class IndexHandler(tornado.web.RequestHandler):
def get(self, *args, **kwargs):
# 显示index.html模板,但是此时并没有向模板网页传递任何数据,仅仅显示罢了
self.render("index.html") class CreateUserHandler(tornado.web.RequestHandler):
def post(self, *args, **kwargs):
# json
post_data = self.request.body_arguments
post_data = {x: post_data.get(x)[0].decode("utf-8") for x in post_data.keys()}
if not post_data:
post_data = self.request.body.decode('utf-8')
post_data = json.loads(post_data)
# 不仅仅是要引用模板网页user.html,还要向这个网页传递一些数据,
# 例如username = user_name,含义就是,
# 在模板中,某个地方是用username来标示得到的数据,
# 而user_name是此方法中的一个变量,也就是对应一个数据,
# 那么模板中的username也就对应了user_name的数据,
# 这是通过username = user_name完成的 self.render("user.html", **post_data) # user_name的数据是哪里来的呢?就是在index.html页面的表单中提交上来的。
# 注意观察路径的设置,r"/user", CreateUserHandler,也就是在form中的action = '/user',
# 就是要将数据提交给UserHandler处理,并且是通过post方法。所以,在UserHandler类中,有post()
# 方法来处理这个问题。 handlers = [
(r"/", IndexHandler),
(r"/user", CreateUserHandler)
]
# 获取存放模板目录template的路径
template_path = os.path.join(os.path.dirname(__file__), "template") if __name__ == '__main__':
options.parse_command_line()
app = tornado.web.Application(handlers=handlers,
template_path=template_path)
http_server = tornado.httpserver.HTTPServer(app)
http_server.listen(options.port)
tornado.ioloop.IOLoop.instance().start()

运行:

python2.7 plat.py --port=8000

访问index.html:

http://127.0.0.1:8000/

填写form表单, 提交数据,自动跳转到user.html

使用curl提交post数据:

curl -H "Content-Type:application/json" -X POST --data '{"username": "北京1245", "website": "3222w", "email": "adsf@sdfa.com", "language": "方言"}' http://127.0.0.1:8000/user

tornado解析post数据的问题的更多相关文章

  1. jQuey知识点三 解析json数据

    1.解析简单数据 @{ Layout = null; } <!DOCTYPE html> <html> <head> <meta name="vie ...

  2. iOS关于XML解析请求数据

    XML数据的请求: 和json请求几乎一样,只有请求参数修改为xml即可: AFHTTPSessionManager *manager = [AFHTTPSessionManager manager] ...

  3. 使用Python解析JSON数据的基本方法

    这篇文章主要介绍了使用Python解析JSON数据的基本方法,是Python入门学习中的基础知识,需要的朋友可以参考下:     ----------------------------------- ...

  4. iOS解析XML数据

    iOS中解析XML数据的类是  NSXMLParser,详细使用方法如下: 假设现在在内存中有XML的二进制数据对象(NSData):data(该数据可能来自网络,也可能是本地的文件数据),设置NSX ...

  5. 使用jQuery解析JSON数据

    我们先以解析上例中的comments对象的JSON数据为例,然后再小结jQuery中解析JSON数据的方法. 上例中得到的JSON数据如下,是一个嵌套JSON: {"comments&quo ...

  6. oracle xmltype导入并解析Excel数据 (四)特别说明

    1.Excel导出,此处没有给出 2.错误原因在中间表,T_EXCEL_IMPORT_GENERATION,其中errormsg不为空的数据 3,中间表入库过程: 需要自己实现,为一个存储过程,存储过 ...

  7. oracle xmltype导入并解析Excel数据 (三)解析Excel数据

    包声明 create or replace package PKG_EXCEL_UTILS is -- Author: zkongbai-- Create at: 2016-07-06-- Actio ...

  8. oracle xmltype导入并解析Excel数据--前言

    通常,很多的时候,我们需要导入Excel数据到系统中,但是Excel数据需要我们去各种校验,比如身份证校验,手机号码校验等等. 校验失败的数据,提供Excel导出错误原因,提示给用户. 如此,如果校验 ...

  9. [转]javascript eval函数解析json数据时为什加上圆括号eval("("+data+")")

    javascript eval函数解析json数据时为什么 加上圆括号?为什么要 eval这里要添加 “("("+data+")");//”呢?   原因在于: ...

随机推荐

  1. 使用Spring Cloud OAuth2和JWT保护微服务

    采用Spring Security AOuth2 和 JWT 的方式,避免每次请求都需要远程调度 Uaa 服务.采用Spring Security OAuth2 和 JWT 的方式,Uaa 服务只验证 ...

  2. hdu.. 基础二分的精度问题

    #include<stdio.h>#include<iostream>using namespace std;double f(double x){ return 8*x*x* ...

  3. snort_inline

    snort_inline Link   http://snort-inline.sourceforge.net/oldhome.html What is snort_inline? snort_inl ...

  4. vue+iview tables多个分页实现

    如果一个页面有多个分页那么可以把每个page和pageSize放到一个对象中,如下: dataList: { name: 'dataList', // 方便取到dataList对象 id: null, ...

  5. 如何设置MySql Server远程访问(Debian Linux)

    1. 登录Mysql Server: $mysql -u root -p 2. 检查网络,Server是否允许远程连接: mysql> show variables like '%skip_ne ...

  6. js同时获取多个共同class内容标签内容集合

    1.获取标签内容  标签如下:   <img image-code="#qq_1_gif#" class="emoji_icon" src="i ...

  7. node.js 微信开发2-消息回复、token获取、自定义菜单

    项目结构 >config/wechat.json 微信公众号的配置文件 >controllers/oauth.js 微信网页授权接口(下一篇再细讲讲) >controllers/we ...

  8. iview DatePicker 只能选本月

    html <FormItem label="活动时间" prop="activity_time"> <DatePicker v-model=& ...

  9. Window Server 2008 概述

    Windows历史版本 Windows工作站发展历史 Windows95——>Windows98——>Windows2000——>WindowsXP——>Vista——> ...

  10. nginx + php-fpm 搭建owncloud

    本文首发:https://www.cnblogs.com/somata/p/NgnixAndPhp-fpmBuildOwncloud.html 今天新研究的nginx,用owncloud来测试一下学的 ...