首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

Django REST 框架详解 04 | 序列化与反序列化及二者整合

1.视图 2.路由 3.接口测试 一、序列化 1.步骤 model s.py,定义表与字段,及表关系 serializes.py 中序列化与反序列化 views.py 中写 get,post 等操作...import models # 基表 # 提供公用的字段,而不创建表 from django.contrib.auth.models import User class BaseModel(models.Model...', 'create_time') # 排除字段,剩下的显示,不可与 fields 共存 # depth = 1 # 自动联表查询深度 5.视图 views.py from django.shortcuts...return attrs 2.视图 views.py from django.shortcuts import render from rest_framework.response import Response...三、序列化与反序列的整合 从数据的安全性和健壮性来考虑,所有的自定义字段不能与 model 的原字段相同 因为序列化是将外键字段作为 Dict,而反序列化会将外键字段作为 Object 1.视图 views.py

96110
您找到你想要的搜索结果了吗?
是的
没有找到

学习版pytest内核测试平台开发万字长文入门篇

接着新建一个user/serializers.py文件写序列化的代码。Django序列化是指,把数据库的数据转化为json返回给前端,反序列化是指把前端传过来的json写入数据库。...后面的代码就集中在serializers.py和views.py两个文件,序列化器提供数据库表字段和响应json的序列化和反序列化,视图使用序列化器,编写业务处理代码。...由于新增用户用户列表展示的字段不一样,所以给同一个User模型创建了2个序列化器。图中标红了代码是把int的id值转化为了str类型,方便前端处理。...除了类视图,Django也提供了函数视图,并且Django REST framework提供了函数视图的方法装饰器,可以像flask框架一样,感受写纯后端接口的体验,这个方法来写修改密码接口: ?...修改用户,修改用户名、密码,修改测试角色用户为管理员角色,重新登录,能看到用户名、密码已更新为修改后的用户名、密码,并且管理员角色生效,能登进去看到后台管理功能。

4.9K30

构建强大的API-Django中的REST框架探究与实践

Django REST框架提供了强大的数据验证机制和错误处理功能,让我们能够轻松地处理各种情况。数据验证通过在序列化器中定义字段,并配置相应的验证规则,可以实现数据的验证。...数据序列化与性能优化在处理大量数据时,有效地序列化和反序列化数据对性能至关重要。Django REST框架提供了丰富的序列化和性能优化功能,可以帮助我们提高应用程序的性能和效率。...Django REST框架提供了一些性能优化技巧,可以帮助我们提高序列化和反序列化操作的效率。...文件上传通过使用Django REST框架提供的FileField或ImageField字段,我们可以轻松地处理文件上传。...首先,我们学习了如何使用Django REST框架来创建简单的API端点,包括定义模型、序列化器、视图集以及路由配置等。

32620

搭建restful api后台

POST - 创建 PUT - 编辑 DELETE - 删除 今天要讲的是rest_framework框架,它是基于Django的,帮助我们快速开发符合RESTful规范的接口框架。...一个亮点在于序列化器可以定义一些字段,让进出的数据可以“一个萝卜一个坑”地填入序列化器,从而就可以方便地进行格式转化,顺便还可以做做数据校验这种工作。...我们通过继承Serializer类定义自己的序列化器类。通常在类中需要指出本序列化器所有需要进行处理的字段名和字段类型,看起来有点像在定义一个Model或者一个Form。 OK, 开战吧。...然后做接口: 实现序列化器 我们使用Django REST framework 提供的序列化器简化代码。...fields = '__all__' # 要序列化字段 建立views.py from rest_framework import generics from .serializers

2K50

python教程

(serializer class)的第一部分定义了一些需要被序列化/反序列化字段。...序列化类(serializer class)与Django的表单类(Form class)非常相似,包括对各种字段有相似的确认标志(flag),例如required,max_length和default...以Django提供表单(Form)类和模型表单(ModelForm)类相同的方式,REST 框架包括了实例化(Serializer)类和模型实例化(ModelSerializer)类。...用我们的序列化来写常规的Django视图 让我们看看,使用我们新的序列化类,我们怎么写一些API视图。此刻,我们不会使用REST框架的其他特性,仅仅像写常规Django视图一样。...首先,让我们添加几个字段。其中一个字段将显示出哪个用户创建里snippet数据。另一个字段将用于HTML代码高亮。

5K10

Django Swagger接口文档生成

简介 Swagger:是一个规范和完整的框架,用于生成、描述、调用和可视化RESTful风格的Web服务。总体目标是使客户端和文件系统源代码作为服务器以同样的速度来更新。...接入Swagger 大致步骤 1.安装django-rest-swagger 2.进入到setting.py文件,添加django-rest-swagger应用 3.进入到views.py,将之前定义的...自带的2个表,进行序列化。...            返回所有用户最近加入的用户排序         create:             创建新用户         delete:             删除现有用户         ...partial_update:             更新现有用户上的一个或多个字段         update:             更新用户     """     '''查看,编辑用户的界面

4.1K40

DRF比Django的认证和权限高在哪里

serializers.py 添加UserSerializer,由于User没有snippets字段,所以需要显式添加: from django.contrib.auth.models import User...因为前面只给Snippet添加了owner字段,还没有写反序列化更新模型的代码,所以通过请求访问视图,再尝试反序列化的时候,报错了。...对象级权限 为了更细粒度的控制权限,让用户只能编辑自己创建的snippet,新建snippets/permissions.py: from rest_framework import permissions...其他认证方式 本文使用的认证方式是默认的SessionAuthentication和BasicAuthentication,只要数据库的用户名、密码和请求中的用户凭证(用户名、密码)匹配上了,就认为认证成功...参考资料: https://www.django-rest-framework.org/tutorial/4-authentication-and-permissions/

1.5K20

Python用Django写restful api接口

我是通过Django+rest_framework来写的。 Django 是用Python开发的一个免费开源的Web框架,可以用于快速搭建高性能,优雅的网站。...views.py 处理用户发出的请求,从urls.py中对应过来, 通过渲染templates中的网页可以将显示内容,比如登陆后的用户名用户请求的数据,输出到网页。...,rest_framework是一套基于DjangoREST 框架,是一个强大灵活的构建 Web API 的工具包。...Serializer类 提供序列化和反序列化的途径,使之可以转化为,某种表现形式如json。...还有个问题 我们的数据有好几千条,一块返回来很不合理,所以需要分页,当然rest_framework框架提供了这个功能,post请求不支持,需要自己查数据库或者切片来进行返回。

2.2K20

DRF JWT认证(二)

id,用户名 3)用头、体加密字符串通过加密算法+秘钥加密得到 签名字符串 拼接成token返回给前台 认证:根据客户端带token的请求 反解出 user 对象 1)将token ....和djangorestframework-simplejwt djangorestframework-jwt:https://github.com/jpadilla/django-rest-framework-jwt...} ··· 签发总结 从obtain_jwt_token开始, 通过ObtainJSONWebToken视图类处理,其实是父类JSONWebTokenAPIView的post方法通过传入的用户名和密码处理获取当前用户...源码中签发校验都在序列化类中完成,这种写法确实比较常用,我们来使用这种方式自定义,将上面视图的校验逻辑写到序列化类中,这个序列化类只用来做反序列化,这样我们就可以利用 反序列化字段校验功能来帮助我们校验...是序列化类和视图类沟通的桥梁 自定义认证类 auth.py import jwt from django.utils.translation import ugettext as _ from rest_framework

1K20

跟着官方文档学Python——Django Rest framework

跟着官方文档学Python Django Rest framework 这周将会持续更新跟着官方文档学Python系列文章,主要是围绕web框架以及其他后端组件的官方文档展开学习。...DELETE http://[hostname]/api/users/[user_id] 删除用户 什么是序列化和反序列化?...Django Rest framework Django REST framework是一个内置在django里面的子应用,可以快速的开发REST API接口应用。...'rest_framework', ] 在项目中如果使用rest_framework框架实现API接口,主要有以下三个步骤: 将请求的数据(如JSON格式)转换为模型类对象 通过模型类对象进行数据库操作..._all__" # 对所有字段操作 # 验证数据的方法[反序列化:接收客户端的数据] # 操作数据的带密码[反序列化:保存数据(添加/更新)] 编写视图views.py from

2.3K10

Django+Vue开发生鲜电商平台之7.用户登录和注册功能

可以看到,在登录之前,state中name和token均为空,登录之后即变为当前用户用户名和JWT。...在用户进行登录提交后,通过对用户名和密码进行比对,但是如果通过手机号码登录,就可能失败,因为登录时obtain_jwt_token查询数据库默认查询的是用户名和密码,而未查询手机号码,因此需要自定义用户认证方法...serializers.py中定义用户注册的序列化如下: class UserRegSerializer(serializers.ModelSerializer): '''用户序列化'''...4.密码设置的多种方式 进一步完善序列化如下: class UserRegSerializer(serializers.ModelSerializer): '''用户序列化''' code...字段,但是在validate(attrs)又将其删去,导致在序列化时找不到code字段,因此出错,这是需要将字段的write_only设置True,以确保在更新或创建实例时可以使用该字段,但是在序列化表示形式时不包括该字段

4.2K20
领券