python3.x - python django通過ajax向后端傳json怎么解析
問題描述
我的json內容是這樣的:
{ 'type':'user', 'ifor':[{ 'id':001, 'name:'lison'},{ 'id':002, 'name':'wei'} ]}
在JS中我是使用jquery的ajax方法傳的,這樣寫的:
$.ajax('url',{ type:'post', data:{type:'user',ifor: [ {id:001,name:'lison' }, {id:002,name:'wei' }] }, success:function(){}})
我的是python3.6,django是1.11.1,在django中的views.py中該怎么接收呢?我網上查了好多,有的說json.loads(request.body),有說simplejson.loads(request.raw_post_data)的,但貌似都有問題,請問大神該怎么接收并解析呢
問題解答
回答1:前端ajax:
data = {};$.ajax({ type: 'post', url: 'url', dataType: 'json', data: JSON.stringify(data), success: function(result) { }});
后端取值:
import jsondata = json.loads(request.body)print data[’key’]回答2:
你首先得確定你傳給后端的內容, 是什么樣的, 不能直接就是json.loads假設view對應方法源碼如下
def test(req): print(req.POST) # 通過輸出看看前端傳過來的數據是什么 return HttpResponse(’test’)
只有符合’{'aa':'xxx'...}’這樣的json格式才能夠被json.loads識別并反序列化, 如果傳回來的結果不是這樣的json格式, 那么就要調整前端的ajax, 以便能夠構造出這樣的數據, 具體可以通過dataType: json或者通過字符串拼接的方法構造都可以, 詳情可以自行谷歌: ajax傳遞json數據
相關文章:
1. 在mybatis使用mysql的ON DUPLICATE KEY UPDATE語法實現存在即更新應該使用哪個標簽?2. mysql - 表名稱前綴到底有啥用?3. Navicat for mysql 中以json格式儲存的數據存在大量反斜杠,如何去除?4. mysql - 怎么生成這個sql表?5. mysql儲存json錯誤6. 哭遼 求大佬解答 控制器的join方法怎么轉模型方法7. mysql - 數據庫表中,兩個表互為外鍵參考如何解決8. 編輯成功不顯示彈窗9. 怎么php怎么通過數組顯示sql查詢結果呢,查詢結果有多條,如圖。10. sql語句 - 如何在mysql中批量添加用戶?
