728x90
반응형
질문 : 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))
Python 목록을 인코딩하기 위해 simplejson을 사용하고 있습니다 (따라서 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
과 같이 SO 답변에 표시된대로 JsonResponse를 사용하십시오.
from django.http import JsonResponse return JsonResponse({'foo':'bar'})
출처 : https://stackoverflow.com/questions/2428092/creating-a-json-response-using-django-and-python
728x90
반응형
'프로그래밍 언어 > HTML,CSS,JS' 카테고리의 다른 글
요소가 DOM에 표시되는지 확인하는 방법 (0) | 2021.09.29 |
---|---|
라이브러리를 사용하지 않고 JavaScript에서 다른 요소 뒤에 요소를 삽입하는 방법 (0) | 2021.09.29 |
Node.js에서 ES6 가져 오기 하는 방법 (0) | 2021.09.28 |
JSON 개체를 TypeScript 클래스에 캐스팅하는 방법 (0) | 2021.09.28 |
Express.js-app.listen VS server.listen (0) | 2021.09.28 |