一、django创建:
终端运行创建项目的命令 :
django-admin startproject 项目名
编译器就是能够将python源代码转为计算机可识别的机器语言去运行的一个工具,而编辑器则是可以用来编写python代码的程序,像记事本也是编辑器,而Pycharm的定义为IDE,也就是集成开发环境。它包含了编译器和编辑器这两个工具的所有功能。
创建一个应用(app):
python manage.py startapp 应用名
二、基础配置:
创建虚拟环境:
File >>> Settings >>>Project:项目名同名 >>> 下图:


点击ok后重新打开终端(Terminal)就能进入虚拟环境了。
手动进入虚拟环境:
如果没有自动进入的话,可以在pycharm的终端中cd进入venv文件夹下的Scripts文件夹,执行activate脚本进入,activate.bat是退出。

使用django的需要的最基础包安装:
Django #django框架
django-cors-headers #跨域
djangorestframework #drf 框架
下载使用国内的镜像源更快:
清华:
https://pypi.tuna.tsinghua.edu.cn/simple
阿里云:
http://mirrors.aliyun.com/pypi/simple/
中国科技大学
https://pypi.mirrors.ustc.edu.cn/simple/
手动添加镜像源在路径前面加 -i,例如:
pip install 下载的模块名 -i https://pypi.tuna.tsinghua.edu.cn/simple
跨域:
然后再注册跨域、DRF框架、自己创建的应用,配置跨域,选择数据表。

跨域基础操作:
#可以允许所有域名跨域访问
CORS_ORIGIN_ALLOW_ALL = True
#也可以手动配置
#1、配置白名单
CORS_ORIGIN_WHITELIST = (
‘*’(全部),
‘http://localhost:8080’(指定路径),
)
#2、允许携带cookie
CORS_ALLOW_CREDENTIALS = True
#3、允许的请求方法
CORS_ALLOW_METHODS = (
‘PUT’,
‘DELETE’,
‘GET’,
‘POST’,
‘OPTIONS’
)
#4、允许的请求头
CORS_ALLOW_HEADERS = (
‘x-requested-with’,
‘Access-Control-Allow-Origin’,
‘author’,
‘authorization’,
‘content-type’,
)
#5、配置静态文件
STATICFILES_DIRS=[
os.path.join('static')
]
配置数据库:

别忘了打开与项目名同名文件夹下的_init_.py,否则报错:

语言选择---->setting:

路由分配:
总路由分配到指定文件夹的文件

在指定文件里分配路由

三、模型类:
1、字段类型:
使用时需要继承django.db.models,字段类型如下:
AutoField:自动增长的IntegerField,通常不用指定,不指定时Django会自动创建属性名为id的自动增长属性。
BooleanField:布尔字段,值为True或False
NullBooleanField:支持Null、True、False三种值。
CharField(max_length=字符长度):字符串,参数max_length表示最大字符个数。
TextField:大文本字段,一般超过4000个字符时使用
IntegerField:整数
DecimalField(max_digits=None,decimal_places=None):十进制浮点数
参数max_digits表示总位数
参数decimal_places表示小数位数
FloatField:浮点数
DateField[auto_now=False, auto_now_add=False]):日期
参数auto_now表示每次保存对象时,自动设置该字段为当前时间,用于”最后一次修改”的时间戳,它总是使用当前日期,默认为false
参数auto_now_add表示当对象第一次被创建时自动设置当前时间,用于创建的时间戳,它总是使用当前日期,默认为false
参数auto_now_add和auto_now是相互排斥的,组合将会发生错误 TimeField:时间,参数同DateField
DateTimeField:日期时间,参数同DateFie
FileField:上传文件字段
ImageField:继承于FileField,对上传的内容进行校验,确保是有效的图片
2、属性:
通过选项实现对字段的约束,选项如下:
null:如果为True,表示允许为空,默认值是False
blank:如果为True,则该字段允许为空白,默认值是False
对比:null是数据库范畴的概念,blank是表单验证证范畴的
db_column:字段的名称,如果未指定,则使用属性的名称
db_index:若值为True, 则在表中会为此字段创建索引,默认值是False
default:默认值
primary_key:若为True,则该字段会成为模型的主键字段,默认值是False,一般作为AutoField的选项使用
unique:如果为True, 这个字段在表中必须有唯一值,默认值是False
3、关系字段类型
关系型数据库的关系包括三种类型:
ForeignKey:一对多,将字段定义在多的一端中
teacher = models.ForeignKey(Headmaster,null=True,on_delete=models.SET_NULL)
ManyToManyField:多对多,将字段定义在两端中
teacher =models.OneToOneField(Teacher,primary_key=True,on_delete=models.CASCADE)
OneToOneField:一对一,将字段定义在任意一端中
artist = models.ManyToManyField(Artist)
4、 定义好之后同步到数据库:
#生成迁移文件
python manage.py makemigrations
#同步到数据库中
python manage.py migrate
四、创建模型序列化器:
from rest_framework.serializers import ModelSerializer
class 名称(ModelSerializer):
classMeta:
model= 要序列化的模型名称
files= ‘__all__’
五、创建试图:
APIView调用自:rest_framework.views
Response 调用自 :rest_framework.response
APIView使用例子:
class AddUserView(APIView):
def post(self, request):
serializer = UserSer(data=request.data)
if serializer.is_valid():
serializer.save()
return Response({
'code': 200,
'msg': '员工添加成功'
})
return Response({
'code': 401,
'msg': '员工信息添加失败'
})