django怎么传给前端json接口(django后端返回json数据给前端)

导读:很多朋友问到关于django怎么传给前端json接口的相关问题,本文首席CTO笔记就来为大家做个详细解答,供大家参考,希望对大家有所帮助!一起来看看吧!

Django接受前端数据的几种方法

字符型

字符型的数据相对好获取,前端传递的方法如下:

sendData = {
 "exporttype": exporttype,

"bugids": bugids,

"test": JSON.stringify({"test": "test"})

};

在Django的后端只要使用exporttype = request.GET.get("exporttype")

就能正常的获取到这个数据了。

注意: 在Python2.7中数据是unicode编码的,如果要使用,有时候需要进行转str

结果示例:

Excle type 'unicode'

数组型

获取数组型的数据如果使用获取字符串的数据的方法,打出的结果是None。我们要使用这个方法:

bugids = request.GET.getlist("bugids[]")

这样获取的数据就是数组类型。

注意: 获取的数组中的元素是unicode编码的,在某些时候使用需要转编码

结果示例:

•传递的url

[14/Jul/2016 11:00:41]"GET /testtools/exportbug/?exporttype=Exclebugids%5B%5D=102bugids%5B%5D=101bugids%5B%5D

•获取的数据

[u'102', u'101', u'100', u'99', u'98', u'97', u'96', u'95', u'94', u'93', u'92', u'91', u'90', u'89', u'88', u'87'

字典型

字典型数据其实可以当成字符串数据来处理,获取到对应字符串后使用JSON模块做一下格式化就行了。

对于前端来说,传递字典型的数据就是传递JSON数据,所以使用的方法是:

"test": JSON.stringify({"test": "test"})

结果示例:

{"test":"test"} type 'unicode'

相关源码

•Get方法

Get方法是wsgi里面的一个方法。

def GET(self):

# The WSGI spec says 'QUERY_STRING' may be absent.

raw_query_string = get_bytes_from_wsgi(self.environ, 'QUERY_STRING', '')

return http.QueryDict(raw_query_string, encoding=self._encoding)

最终返回的是一个http.QueryDict(raw_query_string, encoding=self._encoding)http的原始数据,而QueryDict继承于MultiValueDict ,所以我们直接看MultiValueDict就好了。

•MultiValueDict

其实源码看起来并不难。

def get(self, key, default=None):

"""

Returns the last data value for the passed key. If key doesn't exist

or value is an empty list, then default is returned.

"""

try:

val = self[key]

except KeyError:

return default

if val == []:

return default

return val

def getlist(self, key, default=None):

"""

Returns the list of values for the passed key. If key doesn't exist,

then a default value is returned.

"""

try:

return super(MultiValueDict, self).__getitem__(key)

except KeyError:

if default is None:

return []

return default

def __getitem__(self, key):

"""

Returns the last data value for this key, or [] if it's an empty list;

raises KeyError if not found.

"""

try:

list_ = super(MultiValueDict, self).__getitem__(key)

except KeyError:

raise MultiValueDictKeyError(repr(key))

try:

return list_[-1]

except IndexError:

return []

django怎么传给前端json接口(django后端返回json数据给前端)  第1张

django 怎么处理前台发送过去的json数据

#django原始库

import django.http as djangohttp

#django第三方库

import rest_framework.views as rfview

import rest_framework.renderers as rfreader

#自定义库

import CodingPond

class IView( rfview.APIView ):

    renderer_classes = ( rfreader.JSONPRenderer, )

class JSONResponse( djangohttp.HttpResponse ):

    """

    An HttpResponse that renders it's content into JSON.

    """

    def __init__( self, data = None, header = {}, **kwargs ):

        content = rfreader.JSONRenderer().render( data )

        print content

#        content = CodingPond.Authcode_encode( content, "" )

        kwargs['content_type'] = 'application/json'

        super( JSONResponse, self ).__init__( content, **kwargs )

        self._init_header( header )

    def _init_header( self, header ):

        for key, value in header.items():

            self[key] = value

如此,上面是httpTools.IView接口,然后视图继承,分别重写get和post即可

class ClassifyHomeView( httpTools.IView ):

    """

    @attention: 分类主页

    @note: 

      -路径: /classify/init/

      -post: 无

      -返回: {"classify":[分类数据格式]}

    """

    def post( self, request ):

        command = Commands.GetClassifyInfoCommand()

        command.Excute()

        resDic = command.GetResInfo()

        return httpTools.JSONResponse( resDic )

如何在Django中接收JSON格式的数据

下面通过一个例子说明如何从HTML中发送json,并在Django中接收json数据,在HTML中,可以通过JSON对象将数据以Json格式发送到服务器,假设在play.html中有以下内容要发送到服务器:

用户名username

密码password

一个数组,其中每个元素包含: 游戏编号game_id和得分level

那么,,可以使用如下JavaScript(JQuery)代码:

script type="text/javascript"

$(function() {

$('#upload').click(function() {

var json_obj = {

username: $('#username').val(),

password: $('#password').val(),

datas: [

        {

        game_id: $('#datas1').val(),

        level: $('#level1').val()

        },

        {

        game_id: $('#datas2').val(),

        level: $('#level2').val()

        }

   ]

};    //JSON对象   

var json_str = JSON.stringify(json_obj);    //将JSON对象转变成JSON格式的字符串

    $.post("/datasave", json_str, callback, "json");

})

function callback(json){

$('#response').html('code:'+json['status']['code'] + "\tmessage:" + json['status']['message']);

}

})

/script

在上面的代码中,数据将发送到/datasave,在Django中使用request.raw_post_data,并借助simplejson来将其转换为字典dict数据类型,代码如下:

def datasave(request):

    dict = {}

    info = 'Data log save success'

    try:

        if request.method == 'POST':

        //request.raw_post_data从客户端发送过来的原始数据,通过simplejson的loads方法将其转换为字典数据类型req

            req = simplejson.loads(request.raw_post_data)

            username = req['username']

            password = req['password']

            datas = req['datas']

            game_id1 = datas[0]['game_id']

   except:

        import sys

        info = "%s || %s" % (sys.exc_info()[0], sys.exc_info()[1])

    dict['message']=info

    dict['create_at']=str(ctime())

    json=simplejson.dumps(dict)

    return HttpResponse(json)

结语:以上就是首席CTO笔记为大家整理的关于django怎么传给前端json接口的相关内容解答汇总了,希望对您有所帮助!如果解决了您的问题欢迎分享给更多关注此问题的朋友喔~

以上内容为新媒号(sinv.com.cn)为大家提供!新媒号,坚持更新大家所需的互联网后端知识。希望您喜欢!

版权申明:新媒号所有作品(图文、音视频)均由用户自行上传分享,仅供网友学习交流,不声明或保证其内容的正确性,如发现本站有涉嫌抄袭侵权/违法违规的内容。请发送邮件至 k2#88.com(替换@) 举报,一经查实,本站将立刻删除。

(0)
上一篇 2023-09-23 13:19
下一篇 2023-09-23 13:19

相关推荐

发表回复

登录后才能评论