使用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数组)。 我无法弄清楚问题了。 但是我认为我对“回声”做了错误的处理。

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

 import json from django.http import HttpResponse response_data = {} response_data['result'] = 'error' response_data['message'] = 'Some error message' 

Pre-Django 1.7你会像这样返回它:

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

对于Django 1.7+,使用JsonResponse ,如下所示:

 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中的新功能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.dump你的数组。

 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+

 from django.http import JsonResponse def your_view(request): json_object = {'key': "value"} return JsonResponse(json_object) 

官方文档

你会想使用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") 

如何使用谷歌应用程序引擎与Ajax(JSON)?

使用JQuery代码JavaScript:

 $.ajax({ url: '/ajax', dataType : 'json', cache: false, success: function(data) { alert('Load was performed.'+data.ajax_resp); } }); 

代码Python

 class Ajax(webapp2.RequestHandler): def get(self): my_response = {'ajax_resp':'Hello, webapp World!'} datos = json.dumps(my_response) self.response.headers.add_header('content-type', 'application/json', charset='utf-8') self.response.out.write(datos) 

这是我使用基于类的视图的首选版本。 简单地继承基本视图并覆盖get()方法。

 import json class MyJsonView(View): def get(self, *args, **kwargs): resp = {'my_key': 'my value',} return HttpResponse(json.dumps(resp), mimetype="application/json" ) 
 Django code(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> 

在视图中使用这个:

 form.field.errors|striptags 

获取验证消息没有HTML