django初始化项目

1.初始化项目结构└─shiyanlou_project

│ .gitignore
│ README.en.md # 英文
│ README.md # 中文项目简介

├─celery_task # 用来存放celery相关文件
│ init.py

├─db # 数据库相关:1.数据库初始化sql脚本; 2.数据库维护脚本,清
理,备份脚本
├─logs # 存放日志
├─packages # 外部包,原始的,未配置的:1.七牛云sdk;2.阿里云短信;
├─scrips # 脚本目录:1.定时任务脚本;2.页面静态化脚本;处理项目脚本
└─uwsgi_conf # uwsgi配置,日志,pid


└─syl
│ apps (python包) # Django各种app模块
│ libs (python包) # 七牛云sdk+配置
│ utils (python包) # 小工具,常用函数
│ static
│ templates
│ syl(项目配置)
│ manager.py

2.创建Django项目

python manage.py startproject  syl

3.创建user模型 创建三个包

syl) root@dev:shiyanlou_project/syl

libs  apps  utils libs

3.1 创建用户模型user

syl) root@dev:shiyanlou_project/syl/apps

python manage.py startapp user

3.2 在setting.py中注册user模型(第一步)

NSTALLED_APPS = [
'user.apps.UserConfig',
]

3.3 syl/urls.py添加主路由(第二步)

import sys
sys.path.insert(0,os.path.join(BASE_DIR,'apps'))

3.4 创建 user/urls.py子路由文件(第三步)

4.重写Django默认认证用户模型

4.1 user/models.py创建模型:从写django user表


class User(AbstractUser):
  phone = models.CharField('手机号',max_length=20)
  img = models.ImageField(upload_to='user',null=True)
  nick_name = models.CharField('昵称',max_length=20)
  address = models.CharField('地址',max_length=255)
  class Meta:
  db_table = 'tb_user'

4.2 syl/settings.py中注册自己的用户模型类

注册自己的用户模型类:应用名.模型名字,指定我们重写的user表进行身份验证

AUTH_USER_MODEL = 'user.User'

4.3 配置mysql

DATABASES = {
  'default': {
  'ENGINE': 'django.db.backends.mysql',
  'NAME': 'syldb', # 指定数据库名称:MyCRM
  'USER': 'root',
  'PASSWORD': '1',
  'HOST': '127.0.0.1',
  'PORT': '3306',
  }
}

 4.4生成表 

python manager.py makemigrations
python manager.py migrate

django 配置 viewset使用

  

在seettings.py 中注册

NSTALLED_APPS=[

​ 'django_filters',

​ 'rest_framework',

]


REST_FRAMEWORK = {
# 文档报错: AttributeError: ‘AutoSchema’ object has no attribute ‘get_link’
# 用下面的设置可以解决
'DEFAULT_SCHEMA_CLASS': 'rest_framework.schemas.AutoSchema',
# 默认设置是:
# 'DEFAULT_SCHEMA_CLASS': 'rest_framework.schemas.openapi.AutoSchema', # 异常处理器
# 'EXCEPTION_HANDLER': 'user.utils.exception_handler', # Base API policies
'DEFAULT_RENDERER_CLASSES': [
'rest_framework.renderers.JSONRenderer',
'rest_framework.renderers.BrowsableAPIRenderer',
],
'DEFAULT_PARSER_CLASSES': [
'rest_framework.parsers.JSONParser',
'rest_framework.parsers.FormParser',
'rest_framework.parsers.MultiPartParser'
],
# 1.认证器(全局)
'DEFAULT_AUTHENTICATION_CLASSES': [
'rest_framework.authentication.SessionAuthentication', # 使用session时的认证器
'rest_framework.authentication.BasicAuthentication' # 提交表单时的认证器
],
#2.权限配置(全局): 顺序靠上的严格
'DEFAULT_PERMISSION_CLASSES': [
# 'rest_framework.permissions.IsAdminUser', # 管理员可以访问
# 'rest_framework.permissions.IsAuthenticated', # 认证用户可以访问
# 'rest_framework.permissions.IsAuthenticatedOrReadOnly', # 认证用户可以访问, 否则只能读取
# 'rest_framework.permissions.AllowAny', # 所有用户都可以访问
],
#3.限流(防爬虫)
'DEFAULT_THROTTLE_CLASSES': [
'rest_framework.throttling.AnonRateThrottle',
'rest_framework.throttling.UserRateThrottle',
],
#3.1限流策略
'DEFAULT_THROTTLE_RATES': {
'user': '100/hour', # 认证用户每小时100次
'anon': '3/day', # 未认证用户每天能访问3次
}, 'DEFAULT_CONTENT_NEGOTIATION_CLASS': 'rest_framework.negotiation.DefaultContentNegotiation',
'DEFAULT_METADATA_CLASS': 'rest_framework.metadata.SimpleMetadata',
'DEFAULT_VERSIONING_CLASS': None, #4.分页(全局):全局分页器, 例如 省市区的数据自定义分页器, 不需要分页
'DEFAULT_PAGINATION_CLASS': 'rest_framework.pagination.PageNumberPagination',
# 每页返回数量
'PAGE_SIZE': 10, # 默认 None #5.过滤器后端
'DEFAULT_FILTER_BACKENDS': [
'django_filters.rest_framework.DjangoFilterBackend',
# 'django_filters.rest_framework.backends.DjangoFilterBackend', 包路径有变化
], #5.1过滤排序(全局):Filtering 过滤排序
'SEARCH_PARAM': 'search',
'ORDERING_PARAM': 'ordering', 'NUM_PROXIES': None, #6.版本控制:Versioning 接口版本控制
'DEFAULT_VERSION': None,
'ALLOWED_VERSIONS': None,
'VERSION_PARAM': 'version', # Authentication 认证
# 未认证用户使用的用户类型
'UNAUTHENTICATED_USER': 'django.contrib.auth.models.AnonymousUser',
# 未认证用户使用的Token值
'UNAUTHENTICATED_TOKEN': None, # View configuration
'VIEW_NAME_FUNCTION': 'rest_framework.views.get_view_name',
'VIEW_DESCRIPTION_FUNCTION': 'rest_framework.views.get_view_description', 'NON_FIELD_ERRORS_KEY': 'non_field_errors', # Testing
'TEST_REQUEST_RENDERER_CLASSES': [
'rest_framework.renderers.MultiPartRenderer',
'rest_framework.renderers.JSONRenderer'
],
'TEST_REQUEST_DEFAULT_FORMAT': 'multipart', # Hyperlink settings
'URL_FORMAT_OVERRIDE': 'format',
'FORMAT_SUFFIX_KWARG': 'format',
'URL_FIELD_NAME': 'url', # Encoding
'UNICODE_JSON': True,
'COMPACT_JSON': True,
'STRICT_JSON': True,
'COERCE_DECIMAL_TO_STRING': True,
'UPLOADED_FILES_USE_URL': True, # Browseable API
'HTML_SELECT_CUTOFF': 1000,
'HTML_SELECT_CUTOFF_TEXT': "More than {count} items...", # Schemas
'SCHEMA_COERCE_PATH_PK': True,
'SCHEMA_COERCE_METHOD_NAMES': {
'retrieve': 'read',
'destroy': 'delete'
},
}

  

创建 user/serlizers.py 写序列化器

 

def validata_address(self,data):

    if data=='测试':
raise serializers.ValidationError('请重新填写地址') # 有错就抛出异常
return data # 没错就返回结果
def validate_phone(self,data):
# 不符合手机格式
# raise serializer.ValidationError('手机号格式不正确')
model=self.root.Meta.model
num=model.object.filter(phone=data).count()
if num>0:
raise serializers.ValidationError('已存在手机号')
return data
# 3 所有属性验证
def validate(self,attrs):
# attrs:{"username":"zhangsan","phone":"110",}
# 所有属性 验证器
#self.context 中有request 和views 上下文
#self.context['view'].action 跨域取到动作
# attrs 是需要序列化数据
# raise serializers.ValidationError('xxx错误')
return attrs # 没问题返回数据
class Meta:
model=User
fields='__all__'
read_only_fields=('',)
extra_kawargs={
'address':{
'min_length':5, # 给地址增加 最小长度 限制
'default':'默认测试地址' #增加默认值
}
}  

在 views 写入

from django.shortcuts import render

from django.http import HttpResponse
from django_filters.rest_framework import DjangoFilterBackend
from rest_framework import viewsets
from rest_framework.authentication import BasicAuthentication,SessionAuthentication
from rest_framework.decorators import action
from rest_framework.filters import OrderingFilter
from rest_framework.permissions import AllowAny,IsAdminUser,IsAuthenticated,IsAuthenticatedOrReadOnly
from rest_framework.response import Response
from rest_framework.throttling import UserRateThrottle
from rest_framework.pagination import PageNumberPagination
from rest_framework.views import APIView
from rest_framework.permissions import BasePermission,SAFE_METHODS
from user.models import User
from user.serializers import UserSerlizer,UserUnActiveSerializer def index(request):
# 需要认证才能访问的视图
return HttpResponse('hello')
class PageNum(PageNumberPagination):
# 查询字符串中代表每页返回数据数量的参数名,默认值为:None
page_size_query_param = 'page_size'
# 查询字符串中代表页码的参数名,默认值为:page
#page_query_param='page_size'
max_page_size = 2
class MyPermissio(BasePermission):
def has_permission(self, request, view):
print(view.kwargs.get('pk'),request.user.id)
'''判断用户对使用次权限类的视图都有权限'''
# 任何用户对使用次权限的视图都要访问权限
print(request)
if request.user.is_superuser:
# 管理员对用户模型具有访问权
return True
elif view.kwargs.get('pk')==str(request.user.id):
return True
return False class UserViewSet(viewsets.ModelViewSet):
queryset = User.objects.all()
serializer_class = UserSerlizer
pagination_class = PageNum
# 限流自定义
throttle_classes = [UserRateThrottle]
# 指定过滤方法
filter_backends = (DjangoFilterBackend,OrderingFilter)
ordering_fields=('data_joined','id')
filter_fields=('username','phone','is_active')
  def get_serializer_class(self):
return UserSerializers

urls.py

from django.contrib import admin
from django.urls import include,path
from user import views
from rest_framework.routers import SimpleRouter,DefaultRouter
'''
自动生成路由方法 必须用视图集
routed=DefaultRouter() 没有跟路由 /user/ 无法识别
'''
routed=DefaultRouter()
routed.register(r'user',views.UserViewSet)
urlpatterns = [
path('index', views.index),
path('api-auth/',include('rest_framework.urls',namespace='rest_framework')) # 认证地址
] urlpatterns+=routed.urls

  

django 初始化项目 和modelviewset 使用的更多相关文章

  1. Django练习项目之搭建博客

    背景:自从今年回家过年后,来到公司给我转了试用,我的学习效率感觉不如从前,而且刚步入社会我总是想要怎么想明白想清楚一些事,这通常会花掉,消耗我大量的精力,因为我想把我的生活管理规划好了,而在it技术学 ...

  2. Django 初始化数据库

    django 初始化数据库 刷新数据库guoguos-MacBook-Pro:mysite guoguo$ python manage.py sqlflushBEGIN;SET FOREIGN_KEY ...

  3. python3-Django初始化项目详细

    0.背景 近期在学习django,在初始化项目的时候遇到了一丢坑,记录一下. 1.安装django 下载安装包解压出来后,python3 setup.py install 即可 2.创建项目 djan ...

  4. day1(初始化项目结构)

    1.初始化项目结构  └─shiyanlou_project    │  .gitignore    │  README.en.md           # 英文    │  README.md    ...

  5. 使用node初始化项目

    初始化项目 在建项目的时候经常会建很多文件夹和文件,今天使用node初始化项目自动生成这些内容. 执行步骤 执行命令 node init 初始化项目生成package.json 设置配置文件 var ...

  6. django创建项目

    django创建项目 安装django pip install django==1.9 Note: C:\Python34\Scripts\pip.exe 创建项目 django-admin star ...

  7. Python Django CMDB项目实战之-3创建form表单,并在前端页面上展示

    基于之前的项目代码 Python Django CMDB项目实战之-1如何开启一个Django-并设置base页.index页.文章页面 Python Django CMDB项目实战之-2创建APP. ...

  8. Python Django CMDB项目实战之-2创建APP、建模(models.py)、数据库同步、高级URL、前端页面展示数据库中数据

    基于之前的项目代码来编写 Python Django CMDB项目实战之-1如何开启一个Django-并设置base页index页文章页面 现在我们修改一个文章列表是从数据库中获取数据, 下面我们就需 ...

  9. Python Django CMDB项目实战之-1如何开启一个Django-并设置base页、index页、文章页面

    1.环境 win10 python 2.7.14 django 1.8.2 需要用到的依赖包:MySQLdb(数据库的接口包).PIL/pillow(处理图片的包) 安装命令: pip install ...

随机推荐

  1. SQL 查找"存在",别再用 count 了,很耗费时间的!

    根据某一条件从数据库表中查询 『有』与『没有』,只有两种状态,那为什么在写SQL的时候,还要SELECT count(*) 呢? 无论是刚入道的程序员新星,还是精湛沙场多年的程序员老白,都是一如既往的 ...

  2. 新鲜出炉,这是全网讲的最详细的springboot整合消息服务了吧,建议收藏!

    springboot整合activeMq ActiveMq是Apache提供的开源消息系统采用java实现, 很好地支持JMS(Java Message Service,即Java消息服务) 规范 A ...

  3. 攻克弹唱第九课(如何运用好G大调和弦)

    在本期文章中,笔者将使用guitar pro7软件与大家分享如何运用好G大调音阶的经验. 众所周知,在我们学习吉他的过程中,先从C大调开始,再以G大调为深入,然后才走过入门的阶段.很多朋友都觉得自己对 ...

  4. 用Camtasia来快速地给视频添加水印

    在日常生活中,视频的流行度越来越高,各种短视频的软件蜂拥上市,所以越来越多的人走上了自媒体的道路,在这条路上,谁的视频更加的精致,谁才能获得更多的关注度,相应的也能增加自己的人气. 但是在制作视频的过 ...

  5. Python正则表达式大全

    前言 正则表达式是对字符串(包括普通字符(例如,a 到 z 之间的字母)和特殊字符(称为"元字符"))操作的一种逻辑公式,就是用事先定义好的一些特定字符.及这些特定字符的组合,组成 ...

  6. Java蓝桥杯——排序练习:选美大赛

    选美大赛 在选美大奖赛的半决胜赛现场,有一批选手参加比赛,比赛的规则是最后得分越高,名次越低.当半决决赛结束时,要在现场按照选手的出场顺序宣布最后得分和最后名次,获得相同分数的选手具有相同的名次,名次 ...

  7. Java基础教程——命令行运行Java代码

    视屏讲解:https://www.bilibili.com/video/av48196406/?p=4 命令行运行Java代码 (1)使用记事本新建文本文件[Test.java]. 注意,默认状态下W ...

  8. C语言精华——内存管理,很多学校学习不到的知识~

    在编写程序时,通常并不知道需要处理的数据量,或者难以评估所需处理数据量的变动程度.在这种情况下,要达到有效的资源利用--使用内存管理,必须在运行时动态地分配所需内存,并在使用完毕后尽早释放不需要的内存 ...

  9. Pytest系列(十三)- 重复执行之pytest-repeat的使用

    写在前面 这个插件,可以帮助我们很好的解决自动化测试过程中的一些偶线性bug难以复现的问题,但前提是,当前自动化脚本是独立的,不依赖任何其他脚本.个人觉得还是失败重运行的一种体现,就和TestNG是一 ...

  10. nameServer路由发现

    RocketMQ路由发现是非实时的,当Topic路由出现变化时,NameServer不主动推动给客户端,而是客户端定时拉取主题最新的路由 总结: topic路由的是brokername