静态文件配置
-
默认情况下所有的html文件都是放在templates文件夹内
-
什么是静态文件
网站所使用到的提前写的css,js,第三方模块,图片都叫做静态文件
-
默认情况下网站所使用到的静态文件资源全部会放在static文件夹下
通常情况下,在static文件夹内部还会再建其他文件夹
css 文件夹
js 文件夹
font 文件夹
img 文件夹
Bootstrap
fontawesome
为了更加方便的管理文件
django中需要你手动创建静态文件存放的文件夹
STATIC_URL = '/static/' # 访问静态文件资源的接口前缀,通常情况下接口前缀的名字也叫static
# 手动开设静态文件访问资源
STATICFILES_DIRS = [ # 静态资源所在的文件夹路径
os.path.join(BASE_DIR, 'static'), # 将static文件里面所有的资源暴露给用户
os.path.join(BASE_DIR, 'static1'), # 将static1文件里面所有的资源暴露给用户
]
-
静态文件动态绑定
{% load static %} <link rel="stylesheet" href="{% static 'bootstrap-3.3.7-dist/css/bootstrap.min.css' %}"> <script src="{% static 'bootstrap-3.3.7-dist/js/bootstrap.min.js' %}"></script>
请求方式
form表单默认是get请求
get请求也能够携带参数
http://127.0.0.1:8000/login/?username=jason&password=jason123
特点:url?xxx=xxx&yyy=yyy
1. 携带的数据不安全
2. 携带的数据大小有限制,最大好像应该差不多是4KB
3. 通常只会携带一些不是跟重要的数据
action
- 不写默认朝当前地址提交
- 只写后缀
- 写全路径
前期我们在朝后端提交post请求出现403 的情况你需要去配置文件中注释掉一行内容
MIDDLEWARE = [ 'django.middleware.security.SecurityMiddleware', 'django.contrib.sessions.middleware.SessionMiddleware', 'django.middleware.common.CommonMiddleware', # 'django.middleware.csrf.CsrfViewMiddleware', 'django.contrib.auth.middleware.AuthenticationMiddleware', 'django.contrib.messages.middleware.MessageMiddleware', 'django.middleware.clickjacking.XFrameOptionsMiddleware',]
django后端的视图函数 默认处理的是get请求
无论是发get请求还是post请求 都是执行视图函数
get请求指向拿到login页面
post请求想提交数据 然后后端做校验
request方法初识
request.method 获取请求方式,并且以纯大小的字符串表示
request.POST 获取用户提交的post请求数据
# 如何获取用户数据
request.POST.get() # 默认只会获取列表最后一个参数
request.GET.getlist() # 获取一个列表
request.GET 获取用户提交的get请求数据
# 如何获取用户数据
request.GET.get() # 默认只会获取列表最后一个参数
request.GET.getlist() # 获取列表
Django连接数据库
必须要有两步操作
-
settings文件的配置
DATABASES = { 'default': { 'ENGINE': 'django.db.backends.mysql', # 指定数据库类型 'NAME': 'day49', # 指定库的名字 'USER':'root', # 注意 键必须是全大写 'PASSWORD':'123qwe', 'HOST':'127.0.0.1', 'PORT':3306, 'CHARSET':'utf8' } }
-
主动告诉django,不要使用默认的mysqldb连接,而是用pymysql
你可以在项目名下的
__init__.py
中书写也可以在应用名下的
__init__.py
中书写import pymysql pymysql.install_as_MySQLdb()
Django orm简介
orm就是对象关系映射
类---表
对象---行记录
类属性---字段
为什么使用orm
能够让不会数据库操作的人也能够简单方便去操作数据库
缺点
封装程度太高 有时候会出现查询效率偏低的问题
Django orm操作
django中如何操作orm
书写模型类
去应用下的models.py中书写模型类(就是类)
数据库迁移命令
- python manage.py makemigrations # 将数据库的修改,记录到migration文件内
- python manage.py migrate # 将修改操作真正的同步到数据库上
上面两条命令必须是成双成对出现
只要修改了models里面跟数据库相关的代码 你就必须重新执行上面两条命令
模型表字段的增删改查
字段的修改
直接修改代码,然后执行数据库迁移命令
方式一:
设置默认值
email = models.EmailField(default='123@qq.com') # varchar
方式二:
设置可以为Null
phone = models.CharField(null=True)
字段的删除
直接注释掉对应的字段 然后再执行数据库迁移命令即可(谨慎使用)
模型表数据的增删改查
查
data = models.User.objects.filter(username='') ## <QuerySet [<User: User object>]>
```
filter返回的结果是一个"列表",里面才是真正的对象
filter括号内可以放多个关键字参数,这多个关键字参数在查找的时候是'and'关系
```
data = models.User.objects.all() # models.User.objects.filter()
```
结果是一个"列表" 里面是一个个的数据对象
```
增
user_obj = models.User.objects.create(username=username,password=password)
print(user_obj,user_obj.username,user_obj.password)
# create方法会有一个返回值,返回值就是当前被创建的对象本身
改
models.User.object.filter(id=1).update(username='',)
# 批量操作 会将filter查询出来的列表中所有的对象全部更新
删(一般情况下不会使用)
models.User.objects.filter(id=delete_id).delete()
# 批量操作 会将filter查询出来的列表中所有的对象全部删除