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 |