使用Django和Python创建JSON响应

我试图将服务器端Ajax响应脚本转换为Django HttpResponse,但显然它不起作用。

这是服务器端脚本:

/* RECEIVE VALUE */
$validateValue=$_POST['validateValue'];
$validateId=$_POST['validateId'];
$validateError=$_POST['validateError'];


/* RETURN VALUE */
$arrayToJs = array();
$arrayToJs[0] = $validateId;
$arrayToJs[1] = $validateError;


if($validateValue =="Testuser"){  // Validate??
$arrayToJs[2] = "true";       // RETURN TRUE
echo '{"jsonValidateReturn":'.json_encode($arrayToJs).'}';  // RETURN ARRAY WITH success
}
else{
for($x=0;$x<1000000;$x++){
if($x == 990000){
$arrayToJs[2] = "false";
echo '{"jsonValidateReturn":'.json_encode($arrayToJs).'}';   // RETURNS ARRAY WITH ERROR.
}
}
}

这是转换后的代码

def validate_user(request):
if request.method == 'POST':
vld_value = request.POST.get('validateValue')
vld_id = request.POST.get('validateId')
vld_error = request.POST.get('validateError')


array_to_js = [vld_id, vld_error, False]


if vld_value == "TestUser":
array_to_js[2] = True
x = simplejson.dumps(array_to_js)
return HttpResponse(x)
else:
array_to_js[2] = False
x = simplejson.dumps(array_to_js)
error = 'Error'
return render_to_response('index.html',{'error':error},context_instance=RequestContext(request))
return render_to_response('index.html',context_instance=RequestContext(request))

我使用simplejson来编码Python列表(因此它将返回一个JSON数组)。我还不能解决这个问题。但是我想我对“回声”做错了什么。

687073 次浏览

我通常使用字典而不是列表来返回JSON内容。

import json


from django.http import HttpResponse


response_data = {}
response_data['result'] = 'error'
response_data['message'] = 'Some error message'

在django 1.7之前,你会这样返回它:

return HttpResponse(json.dumps(response_data), content_type="application/json")

对于Django 1.7+,使用JsonResponse,如这个SO答案所示:

from django.http import JsonResponse
return JsonResponse({'foo':'bar'})

我用这个,效果很好。

from django.utils import simplejson
from django.http import HttpResponse


def some_view(request):
to_json = {
"key1": "value1",
"key2": "value2"
}
return HttpResponse(simplejson.dumps(to_json), mimetype='application/json')

选择:

from django.utils import simplejson


class JsonResponse(HttpResponse):
"""
JSON response
"""
def __init__(self, content, mimetype='application/json', status=None, content_type=None):
super(JsonResponse, self).__init__(
content=simplejson.dumps(content),
mimetype=mimetype,
status=status,
content_type=content_type,
)

在Django 1.7中,JsonResponse对象被添加到Django框架本身,这使得这个任务更加容易:

from django.http import JsonResponse
def some_view(request):
return JsonResponse({"key": "value"})

你会想要使用django序列化器来帮助处理unicode的东西:

from django.core import serializers


json_serializer = serializers.get_serializer("json")()
response =  json_serializer.serialize(list, ensure_ascii=False, indent=2, use_natural_keys=True)
return HttpResponse(response, mimetype="application/json")
这是我使用基于类的视图的首选版本。 简单地继承基本视图的子类并重写get()方法
import json


class MyJsonView(View):


def get(self, *args, **kwargs):
resp = {'my_key': 'my value',}
return HttpResponse(json.dumps(resp), mimetype="application/json" )
from django.http import HttpResponse
import json


class JsonResponse(HttpResponse):
def __init__(self, content={}, mimetype=None, status=None,
content_type='application/json'):
super(JsonResponse, self).__init__(json.dumps(content), mimetype=mimetype,
status=status, content_type=content_type)

在视图中:

resp_data = {'my_key': 'my value',}
return JsonResponse(resp_data)

django 1.7新增功能

你可以使用JsonResponse对象。

从文档中可以看出:

from django.http import JsonResponse
return JsonResponse({'foo':'bar'})

从Django 1.7开始,你就有了一个标准的JsonResponse,这正是你所需要的:

from django.http import JsonResponse
...
return JsonResponse(array_to_js, safe=False)

你甚至不需要json。转储数组。

Django代码views.py:

def view(request):
if request.method == 'POST':
print request.body
data = request.body
return HttpResponse(json.dumps(data))

HTML代码view.html:

<!DOCTYPE html>
<html>
<head>
<script src="http://ajax.googleapis.com/ajax/libs/jquery/1.11.1/jquery.min.js"></script>
<script>
$(document).ready(function(){
$("#mySelect").change(function(){
selected = $("#mySelect option:selected").text()
$.ajax({
type: 'POST',
dataType: 'json',
contentType: 'application/json; charset=utf-8',
url: '/view/',
data: {
'fruit': selected
},
success: function(result) {
document.write(result)
}
});
});
});
</script>
</head>
<body>


<form>
\{\{data}}
<br>
Select your favorite fruit:
<select id="mySelect">
<option value="apple" selected >Select fruit</option>
<option value="apple">Apple</option>
<option value="orange">Orange</option>
<option value="pineapple">Pineapple</option>
<option value="banana">Banana</option>
</select>
</form>
</body>
</html>

对于使用Django 1.7+的用户

from django.http import JsonResponse


def your_view(request):
json_object = {'key': "value"}
return JsonResponse(json_object)

官方文档 .

在View中使用:

form.field.errors|striptags

在没有HTML的情况下获得验证消息

这在Django 1.7或更高版本中非常方便,因为你有JsonResponse类,它是HttpResponse的子类。

from django.http import JsonResponse
def profile(request):
data = {
'name': 'Raghav',
'location': 'India',
'is_active': False,
'count': 28
}
return JsonResponse(data)

对于旧版本的Django,必须使用HttpResponse对象。

import json
from django.http import HttpResponse


def profile(request):
data = {
'name': 'Raghav',
'location': 'India',
'is_active': False,
'count': 28
}
dump = json.dumps(data)
return HttpResponse(dump, content_type='application/json')

使用Django基于类的视图,你可以写:

from django.views import View
from django.http import JsonResponse


class JsonView(View):
def get(self, request):
return JsonResponse({'some': 'data'})

使用Django-Rest-Framework,你可以写:

from rest_framework.views import APIView
from rest_framework.response import Response


class JsonView(APIView):
def get(self, request):
return Response({'some': 'data'})

首先导入这个:

from django.http import HttpResponse

如果你已经有JSON:

def your_method(request):
your_json = [{'key1': value, 'key2': value}]
return HttpResponse(your_json, 'application/json')

如果你从另一个HTTP请求得到JSON:

def your_method(request):
response = request.get('https://www.example.com/get/json')
return HttpResponse(response, 'application/json')

这些答案大多已经过时了。不建议使用JsonResponse,因为它转义字符,这通常是不希望的。以下是我使用的方法:

views.py(返回HTML)

from django.shortcuts import render
from django.core import serializers


def your_view(request):
data = serializers.serialize('json', YourModel.objects.all())
context = {"data":data}
return render(request, "your_view.html", context)

views.py(返回JSON)

from django.core import serializers
from django.http import HttpResponse


def your_view(request):
data = serializers.serialize('json', YourModel.objects.all())
return HttpResponse(data, content_type='application/json')

Vue用户的奖金

如果你想把你的Django Queryset引入Vue,你可以做下面的事情。

template.html

<div id="dataJson" style="display:none">
\{\{ data }}
</div>


<script>
let dataParsed = JSON.parse(document.getElementById('dataJson').textContent);
var app = new Vue({
el: '#app',
data: {
yourVariable: dataParsed,
},
})
</script>
def your_view(request):
response = {'key': "value"}
return JsonResponse(json.dumps(response), content_type="application/json",safe=False)

#指定content_type并使用json.dump() son作为不作为对象发送的内容

通过这种方式,json内容可以作为具有特定文件名的文件下载。

import json
from django.http import HttpResponse


def download_json(request):
data = {'some': 'information'}


# serialize data obj as a JSON stream
data = json.dumps(data)
response = HttpResponse(data, content_type='application/json charset=utf-8')


# add filename to response
response['Content-Disposition'] = 'attachment; filename="filename.json"'
return response