如何在Django中接收JSON格式的数据


Django做了大量工作简化我们的Web开发工作, 这其中当然也包括接收来自客户端的数据这一普遍需求. 大部分时候,从客户端传入的数据主要是FORM的POST数据,和来自URL的GET数据, 在Django中对应了HttpRequest对象的POST和GET属性, 例如读取FORM表单中的用户名username输入框的内容:

def someView(request):
    username = request.POST.get('username');
    ......

在WEB2.0时代, 如果我们从客户端传入的是JSON格式的数据, 上面的方法就无法正常读出数据了. 可能有人要问,为什么一定要用JSON格式的数据, 不直接编码成FORM形式的数据呢? 因为JSON格式能够更好地体现数据的层次结构, 而FORM形式的数据往往只能是单层.

下面通过一个例子演示如何从HTML中发送json,并在Django中接收json数据.

在HTML中,可以通过JSON对象将数据以Json格式发送到服务器,假设在play.html中有以下内容要发送到服务器:

  • 用户名username
  • 密码password
  • 一个数组,其中每个元素包含: 游戏编号game_id和得分level

那么, 可以使用如下JavaScript(JQuery)代码:

<script type="text/javascript">
$(function() {
	$('#upload').click(function() {
		var json_obj = {
				username: $('#username').val(),
				password: $('#password').val(),
				datas: [
				        {
					        game_id: $('#datas1').val(),
					        level: $('#level1').val()
				        },
				        {
					        game_id: $('#datas2').val(),
					        level: $('#level2').val()
				        }
					   ]
				};    //JSON对象   

		var json_str = JSON.stringify(json_obj);    //将JSON对象转变成JSON格式的字符串
	    $.post("/datasave", json_str, callback, "json");
	})

	function callback(json){
		$('#response').html('code:'+json['status']['code'] + "\tmessage:" + json['status']['message']);
	}
})
</script>

在上面的代码中, 数据将发送到/datasave, 在Django中,视图方法若还使用request.POST来读数据, 得到的全是None, 这时得使用request.raw_post_data, 并借助simplejson来将其转换为字典dict数据类型, 然后的使用就简单了,如下:

def datasave(request):
    dict = {}
    info = 'Data log save success'
    try:
        if request.method == 'POST':
            req = simplejson.loads(request.raw_post_data)
            username = req['username']
            password = req['password']
            datas = req['datas']
            game_id1 = datas[0]['game_id']
   except:
        import sys
        info = "%s || %s" % (sys.exc_info()[0], sys.exc_info()[1])

    dict['message']=info
    dict['create_at']=str(ctime())
    json=simplejson.dumps(dict)
    return HttpResponse(json)

request.raw_post_data表示的是从客户端发送过来的原始数据,为了纯字符串, 通过simplejsonloads方法将其转换为字典数据类型req.
上面的代码也演示了如何以JSON格式作为响应值, 而非HTML, 即通过simplejsondumps方法, 将字典数据dict序列化为字符串形式,将通过HttpResponse返回.

Python后台报表综合案例教程

08-28
课程背景:    企业里面很多系统管理后台,用easyui + highcharts + django 进行后台管理的整合,而这块资料在网上资料甚少,很多有经验的朋友在做这块时候也经常出现各种问题,目前我们老师以前在大数据真实项目用到这块,现在受一些网友建议单独录制easyui + highcharts + django,希望可以帮助那些同学。视频+技术文档+源码让你看过后马上也可以搭建起来。  比如现在的友盟 和 百度统计 都是在类似这样的统计,我们会通过2~3个小时左右的课程,让你掌握这样的技术。   目标人群:  1、初级以上普通开发人员  2、web开发人员,对python感兴趣同学  3、对编程感兴趣的同学   课程目录:  01easyui_highcharts_django整合之需求介绍  02easyui_highcharts_django整合通过pycharm创建项目  03easyui_highcharts_django整合配置路由显示第一个页面  04easyui_highcharts_django整合下载easyui资源并且导入到项目里面  05easyui_highcharts_django整合修改配置文件加载static静态文件  06easyui_highcharts_django整合对页面进行修改  07easyui_highcharts_django整合对合并母模板layout  08easyui_highcharts_django整合添加一个新的业务的代码实现流程  09easyui_highcharts_django整合highcharts简单介绍  10easyui_highcharts_django整合highcharts的整合到django里面  11easyui_highcharts_django整合快速做出另一个业务流程  12easyui_highcharts_django整合柱状图  13easyui_highcharts_django后台返回json数据并且展示   14大数据django后台数据保存到mysql里面  15大数据django从mysql里面读取数据并显示到页面上面  课程环境:    环境:win10,  python 2.7.13,  django 1.8.3 ,  pymsql   收获预期:    1.使用django开发项目  2.学会使用easyui框架  3.学会使用highcharts  4.easyui_highcharts_django开发后面展示项目   案例截图:      
©️2020 CSDN 皮肤主题: 大白 设计师: CSDN官方博客 返回首页
实付0元
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、C币套餐、付费专栏及课程。

余额充值