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对 ...
随机推荐
- bzoj千题计划242:bzoj4034: [HAOI2015]树上操作
http://www.lydsy.com/JudgeOnline/problem.php?id=4034 dfs序,树链剖分 #include<cstdio> #include<io ...
- cord-in-a-box 2.0 安装指南
[TOC] 这篇文章简要介绍了 Ciab2.0 的安装. 包括硬件, 软件环境的选择, Ciab2.0的实际部署架构, 安装过程等. 下面就先对 Ciab2.0 部署环境做简要介绍. 1. 概述 这一 ...
- Css之导航栏下拉菜单
Css: /*下拉菜单学习-2017.12.17 20:17 added by ldb*/ ul{ list-style-type:none; margin:; padding:; overflow: ...
- MSIL实用指南-一维数组的操作
本篇讲解怎么生成和操作一维数组.各种数组类型创建的步骤是一样的,但是加载和保存步骤有所不同. 一.创建数组所有类型的一维数组创建都是一样的,分三步.1.加载数组长度2.生成指令 Newarr < ...
- Ubuntu16.04 + Zabbix 3.4.7 邮件报警设置
部署了Zabbix,需要配置邮件报警,在网上找了一些教程,大多是是用的CentOS + Zabbix 2.x版本的,而且还要写脚本,感觉太麻烦了,所以自己结合其他文章摸索了一套配置方法. 先说一下环境 ...
- T410升级笔记
T410 win7 旗舰版 32 sp1 三星 DDR3 1066 mhz core i5 M 540 2.53GHZ 双核 日立 HTS725032A9A364 320G/7200转/分 sa ...
- linux下git常用命令
1 安装: sudo apt-get install git 2 创建一个版本库: 新建一个文件夹,进入这个目录之后 git init 3 创建一个版本: git add 文件名或目录 #表示将当前文 ...
- hdu1050 Moving Tables---贪心
题目链接: http://acm.hdu.edu.cn/showproblem.php?pid=1050 题目大意:就说有一些桌子需要从某些房间搬到另一些房间,但中间只有一条走廊,且走廊中任何一段只能 ...
- append()/extend()/insert()/remove()/del/pop()/slice列表分片
member = ['小甲鱼', 88, '黑夜', 90, '迷途', 85, '怡静', 90, '秋舞斜阳', 88] member.append('字符串')#在列表结尾处增加字符串 memb ...
- js分页效果
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...