Python Django rest framework
本节内容
Django rest framework 安装
Django rest framwwork 环境配置
- 简单举例说明
Django中使用 rest framework
1.1 安装 Django rest framework
建立新的环境 可以忽略
virtualenv env
source env/bin/activate
安装 djangorestframework 模块
pip install django
pip install djangorestframework
pip install markdown # Markdown support for the browsable API.
pip install django-filter # Filtering support
2 Django rest framework 环境配置
1.配置settings文件
在项目配置文件settings的INSTALLED_APPS中添加 ‘rest_framework’

在settings最后一行增加一下内容:允许未认证的用户只读权限
REST_FRAMEWORK = {
# Use Django's standard `django.contrib.auth` permissions,
# or allow read-only access for unauthenticated users.
'DEFAULT_PERMISSION_CLASSES': [
'rest_framework.permissions.DjangoModelPermissionsOrAnonReadOnly'
]
}
3 简单的举例说明
先来看下我Django项目的目录结构

第一步我们需要在 crm_1的 urls下添加 rest framework 的指向信息,这里我们把api的请求指向到app01下的urls.py
urlpatterns = [
url(r'^api/',include('app01.urls') ),
]
在app01的urls.py中写如下内容
#!/usr/bin/env python
# -*- coding:utf-8 -*-
__author__ = '40kuai' from django.conf.urls import url, include
from django.contrib.auth.models import User
from rest_framework import routers, serializers, viewsets # Serializers define the API representation.
class UserSerializer(serializers.HyperlinkedModelSerializer):
class Meta:
model = User
fields = ('url', 'username', 'email', 'is_staff') # ViewSets define the view behavior.
class UserViewSet(viewsets.ModelViewSet):
queryset = User.objects.all()
serializer_class = UserSerializer # Routers provide an easy way of automatically determining the URL conf.
router = routers.DefaultRouter()
router.register(r'users', UserViewSet) # Wire up our API using automatic URL routing.
# Additionally, we include login URLs for the browsable API.
urlpatterns = [
url(r'^', include(router.urls)),
url(r'^api-auth/', include('rest_framework.urls',namespace='rest_framework'))
]
配置了这些之后你就可以启动你的Django项目并且来访问api,
python manage makemigrations
python manage migrate
python manage createsuperuser # 创建第一个用户数据方便在api中查看信息
页面显示

登录后可以查看和编辑数据

下面我们来创建两个有关联关系的表。来看看api怎么显示。
先来创建两个表, 一个角色表。一个菜单表,一个角色可以后多个菜单
from django.db import models # Create your models here. class Role(models.Model):
"""角色表"""
name = models.CharField(max_length=64,unique=True)
menus = models.ManyToManyField("Menu",blank=True,null=True) def __str__(self):
return self.name class Menu(models.Model):
"""一级菜单"""
name = models.CharField(max_length=64)
url_type_choices = ((0,'absolute'),(1,'relative'))
url_type = models.PositiveIntegerField(choices=url_type_choices,default=1)
url_string = models.CharField(max_length=128)
order = models.SmallIntegerField(default=0) def __str__(self):
return self.name class Meta:
unique_together = ("url_string",'url_type')
models.py
在admin.py中注册下, 我们通过Django admin来添加几条数据
from app01 import models admin.site.register(models.Menu)
admin.site.register(models.Role)
admin.py
创建完成后表中的数据
Roles

Menus

下面根据上面实例的配置来先配置Role表,让表Role通过api来显示,并且把各个处理的方法单独分开
先只配置了Role表,来看看效果

在你要显示的表中存在关联关系的时候,需要给关联表也做相应配置
完整的配置 app01目录下的配置
#!/usr/bin/env python
# -*- coding:utf-8 -*-
__author__ = '40kuai' from django.conf.urls import url, include
from app01 import rest_routers # Wire up our API using automatic URL routing.
# Additionally, we include login URLs for the browsable API.
urlpatterns = [
url(r'^', include(rest_routers.router.urls)),
url(r'^api-auth/', include('rest_framework.urls',namespace='rest_framework'))
]
urls.py
#!/usr/bin/env python
# -*- coding:utf-8 -*-
__author__ = '40kuai' from rest_framework import routers
from app01.rest_viewsets import *
"""
负责对url进行绑定
类似与Django admin的注册
""" router = routers.DefaultRouter()
router.register(r'role', RoleViewSet)
router.register(r'menu', MenuViewSet)
rest_routers.py
#!/usr/bin/env python
# -*- coding:utf-8 -*-
__author__ = '40kuai'
from rest_framework import viewsets
from app01.rest_serializers import *
from app01 import models
"""
把数据库中的数据取出来,交给序列化进行处理
类似Django中的的视图函数
"""
class RoleViewSet(viewsets.ModelViewSet):
queryset = models.Role.objects.all()
serializer_class = RoleSerializer class MenuViewSet(viewsets.ModelViewSet):
queryset = models.Menu.objects.all()
serializer_class = MenuSerializer
rest_viewsets.py
#!/usr/bin/env python
# -*- coding:utf-8 -*-
__author__ = '40kuai' from rest_framework import serializers
from app01 import models
"""
序列化要展示的数据
"""
class RoleSerializer(serializers.HyperlinkedModelSerializer):
class Meta:
# depth = 1 # 展示的深度
model = models.Role
fields = ('url','name', 'menus', ) class MenuSerializer(serializers.HyperlinkedModelSerializer):
class Meta:
model = models.Menu
fields = ('url','name', 'url_type','url_string','order' )
rest_serializers.py
现在页面就可以正常访问了。
显示关联表里的详细信息:
serializers 类的配置的class Meta中添加 depth = 2 来指定 数据查询的深度
serializers.HyperlinkedModelSerializer # 显示对象的url
ModelSerializer # 显示对象的id
4 Django 视图函数和rest framework 结合使用
# 接口新加两条路由信息
url(r'^eventlog_list/', views.eventrole_list),
url(r'^eventlog_detail/(\d+)/', views.eventrole_detail),
from django.shortcuts import render # Create your views here.
from rest_framework import serializers
from app01 import models from django.http import HttpResponse, JsonResponse
from django.views.decorators.csrf import csrf_exempt
from rest_framework.renderers import JSONRenderer
from rest_framework.parsers import JSONParser
from rest_framework.decorators import api_view from rest_framework import status
from rest_framework.response import Response class EventRoleSerializer(serializers.ModelSerializer):
class Meta:
model = models.Role
fields = ('id','name', 'menus') @api_view(['GET', 'POST'])
def eventrole_list(request):
"""
List all snippets, or create a new snippet.
"""
if request.method == 'GET':
eventroles = models.Role.objects.all()
serializer = EventRoleSerializer(eventroles, many=True)
return Response(serializer.data) elif request.method == 'POST':
print("request", request.data)
serializer = EventRoleSerializer(data=request.data)
if serializer.is_valid():
serializer.save()
return Response(serializer.data, status=status.HTTP_201_CREATED)
return Response(serializer.errors, status=status.HTTP_400_BAD_REQUEST) @api_view(['GET', 'POST','PUT','DELETE'])
@csrf_exempt
def eventrole_detail(request, pk):
"""
Retrieve, update or delete a code eventlog.
"""
try:
eventrole_obj = models.Role.objects.get(pk=pk)
except models.Role.DoesNotExist:
return HttpResponse(status=404) if request.method == 'GET':
serializer = EventRoleSerializer(eventrole_obj)
return JsonResponse(serializer.data) elif request.method == 'PUT':
print(request)
data = JSONParser().parse(request)
serializer = EventRoleSerializer(eventrole_obj, data=data)
if serializer.is_valid():
serializer.save()
return JsonResponse(serializer.data)
return JsonResponse(serializer.errors, status=400) elif request.method == 'DELETE':
eventrole_obj.delete()
return HttpResponse(status=204)
views.py
自己测得玩玩就好, 这只是个入门。
Python Django rest framework的更多相关文章
- [python]django rest framework写POST和GET接口
版本声明 python3.6.5 Django-2.0.6 djangorestframework-3.8.2 mysqlclient-1.3.12 1.写一个登录接口,不多说,直接上代码 login ...
- python 全栈开发,Day96(Django REST framework 视图,django logging配置,django-debug-toolbar使用指南)
昨日内容回顾 1. Serializer(序列化) 1. ORM对应的query_set和ORM对象转换成JSON格式的数据 1. 在序列化类中定义自定义的字段:SerializerMethodFie ...
- python 全栈开发,Day94(Promise,箭头函数,Django REST framework,生成json数据三种方式,serializers,Postman使用,外部python脚本调用django)
昨日内容回顾 1. 内容回顾 1. VueX VueX分三部分 1. state 2. mutations 3. actions 存放数据 修改数据的唯一方式 异步操作 修改state中数据的步骤: ...
- 使用django rest framework
django 刚接触,想做一些restful api , google了一下,发现有现成的框架.Django REST framework. 对使用做下记录: 安装 从http://django-re ...
- 利用 Django REST framework 编写 RESTful API
利用 Django REST framework 编写 RESTful API Updateat 2015/12/3: 增加 filter 最近在玩 Django,不得不说 rest_framewor ...
- django rest framework 入门
django rest framework 入门1-序列化 Serialization 分类: Python 2013-01-22 22:24 11528人阅读 评论(0) 收藏 举报 djangop ...
- django rest framework
Django-Rest-Framework 教程: 4. 验证和权限 作者: Desmond Chen, 发布日期: 2014-06-01, 修改日期: 2014-06-02 到目前为止, 我们的AP ...
- Django REST Framework学习——Android使用REST方法访问Diango
本文更应该叫做Android如何模拟浏览器访问Django服务器后台. 环境为: Android通过HttpClient访问服务器,从Django中获取json数据,解析显示在UI界面上. 问题为: ...
- Django REST FrameWork中文教程2:请求和响应
从这一点开始,我们将真正开始覆盖REST框架的核心.我们来介绍几个基本的构建块. 请求对象REST框架引入了Request扩展常规的对象HttpRequest,并提供更灵活的请求解析.Request对 ...
随机推荐
- css变化代码2
<!DOCTYPE html><html> <head> <meta charset="utf-8" /> ...
- vue初尝试--新建项目
这是一篇技术贴--如何新建一个基于vue的项目 1.下载对应版本的nodejs安装,下载的nodejs都集成了npm,所以nodejs安装完成之后npm也对应安装完成了. 安装完成之后可以在cmd命令 ...
- AngularJS1.X学习笔记8-自定义指令(上)
AngulaJS的指令是一种非常强大的特性,一个ng-repeat就能让我们非常方便的展示一个数据列表,指令相当于是一个组件,为我们将一些东西封装起来了,提供了复用的可能性.个人认为自定义指令还是比较 ...
- AJAX使用说明书
AJAX简介 什么是AJAX AJAX(Asynchronous Javascript And XML)翻译成中文就是“异步Javascript和XML”.即使用Javascript语言与服务器进行异 ...
- Python-进程与线程理论基础-Day10
进程与线程理论基础 1.背景知识 理论基础: 一 操作系统的作用: 1:隐藏丑陋复杂的硬件接口,提供良好的抽象接口 2:管理.调度进程,并且将多个进程对硬件的竞争变得有序 二 多道技术: 1.产生背景 ...
- 用javascript做别踩白块游戏1
初学Javascript做的一个别踩白块小游戏,代码简陋,如下: <!DOCTYPE html> <html> <head> <!-- 禁用缩放功能 --&g ...
- js new到底干了什么,new的意义是什么?
学过JS的都知道 创建对象可以这样 var obj=new Object(); var obj=new Function(); 用内置的函数对象来构造对象 还可以这样自定义函数 function te ...
- spring-oauth-server实践:授权方式1、2、3和授权方式4的token对象.authorities产生方式比较
授权方式1.2.3和授权方式4的token对象.authorities产生方式不同, 前者使用user_privillege构建, 后者直接使用oauth_client_details.authort ...
- LINGO 基础学习笔记
LINGO 中建立的优化模型可以由5个部分组成,或称为 5 段(section): (1)集合段(SETS):这部分要以"SETS:"开始,以"ENDSETS" ...
- POJ-1753 Flip Game---二进制枚举子集
题目链接: https://vjudge.net/problem/POJ-1753 题目大意: 有4*4的正方形,每个格子要么是黑色,要么是白色,当把一个格子的颜色改变(黑->白或者白-> ...