我使用 JSONP 将数据从otherdomain.com
发送到mydomain.com
然而,当我尝试解析django controller (views.py
)中的JSONP数据时,我变得更加糟糕。
这是我的代码。
mydomain.com
客户页面中的Javascript
jsonData = {
'foo': 'bar',
}
$.ajax({
url: 'http://otherdomain.com/end_point/',
type: 'GET',
contentType: 'application/json; charset=utf-8',
data: jsonData,
dataType : 'jsonp',
jsonp : 'callback'
});
views.py
mydomain.com
)
from django.http import JsonResponse
import json
def decode_jsonp(request):
if 'callback' in request.GET:
json_object = json.loads(request.body) # Raise error
json_object = json.dumps(request.body) # Do not raise error but returns nothing
json_object = json.loads(json.dumps(request.body)) # Raise error
foo = json_object['foo']
return JsonResponse({'foo': foo})
我不知道应该替换json_object = json.loads(request.body)
答案 0 :(得分:4)
JSONP对象周围有括号和回调。但Python的json
模块无法识别JSONP对象。因此,您必须首先通过删除周围的括号和回调名称将其转换为JSON对象。
实施例
>>> data = 'callback({"key": "val"})' # a common JSONP object
>>>
>>> json.loads(data)
# raises ValueError
>>>
>>> data_json = data.split("(", 1)[1].strip(")") # convert to json
>>> data_json
'{"key": "val"}'
>>>
>>> json.loads(data_json)
# success
答案 1 :(得分:1)
感谢@xyres。这是解决方案。
def decode_jsonp(request):
if 'callback' in request.GET:
query_string = request.GET.urlencode()
json_object = {x.split('=')[0]:str(x.split('=')[1]) for x in query_string.split("&")}
foo = json_object['foo']
return JsonResponse({'foo': foo})