Django(二)
目录
Django(二)
静态文件配置
-
默认情况下所有的html文件都是放在templates文件夹内
-
静态文件
网站所使用的css,js,第三方的模块,图片都叫做静态资源
-
默认情况下,网站所用到的静态文件资源全部放在static文件夹下
在Django中,需要我们自己创建static静态文件夹,用于存放静态文件
手动开设静态文件访问资源
django后端如果想想暴露后端资源,必须去urls里面开设相对应的资源接口
STATIC_URL = '/static/' # 访问静态文件资源接口前缀 通常情况下接口前缀的名字也叫static
# 手动开设静态文件访问资源
STATICFILES_DIRS = [ # 静态资源所在的文件夹路径
os.path.join(BASE_DIR,'static'), # 将static文件里面所有的资源暴露给用户
os.path.join(BASE_DIR,'static1'), # 将static文件里面所有的资源暴露给用户
# os.path.join(BASE_DIR,'static2'), # 将static文件里面所有的资源暴露给用户
]
静态文件动态绑定
{% 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>
中间件
朝后端提交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',
]
method
浏览器通过哪种请求方式来访问的,可以通过request.method获取
#request.method 拿到的是字符串大写的请求方式(GET,POST)
def login(request):
if request.method == "POST":
return HttpResponse('收到了')
return render(request,'login.html')
request方法
request方法初识
request.method 获取请求方式 并且纯大写的字符串
request.POST 获取用户提交的post请求数据
如何获取用户数据(******)
request.POST.get() # 默认只会获取列表最后一个元素
request.POST.getlist() # 如果你想获取列表 用getlist()
request.GET 获取用户提交的get请求数据
如何获取用户数据(******)
request.GET.get() # 默认只会获取列表最后一个元素
request.GET.getlist() # 如果你想获取列表 用getlist()
django连接MySQL
django连接MySQL分为两个步骤:
- 配置文件配置
DATABASES = {
'default': {
'ENGINE': 'django.db.backends.mysql', # 指定数据库类型
'NAME': 'django', # 指定库的名字
'USER':'root',
'PASSWORD':'123',
'HOST':'127.0.0.1',
'PORT':3306,
'CHARSET':'utf8',
}
}
#键必须是全大写
-
设置默认数据库连接的模块
django默认用mysqldb连接,需要换成pymysql
#可以在项目名下的__init__.py中书写 #也可以在应用名下的__init__.py中书写 import pymysql pymysql.install_as_MySQLdb()
在Django中操作orm
在应用下的models.py文件中书写模型类
# 1. AutoField ---> 自动递增
# 2. CharField ---> 字符串
# 3. IntegerField ---> 数字型
class User(models.Model):
#如果不指定主键,会自动创建一个id字段作为主键
#如果手动指定了主键,则django将不会再自动创建
id = models.AutoField(primary_key=True)
username = models.CharField(max_length=32)
password = models.CharField(max_length=32)
数据库迁移(同步)命令
# 1. python manage.py makrmigrations
#将数据库的修改先记录到migrations文件内,此时数据库中的数据不发生改变
# 2. python manage.py migrate
#将修改操作真正的同步到数据库中
#上面两条命令必须是成双成对出现
#只要修改了models里面跟数据库相关的代码 你就必须重新执行上面两条命令
模型表字段的增删改
注意:
只要对表字段作了增删改,都需要去执行数据库迁移命令,两条命令一条不能少
字段的修改
直接修改代码 然后执行数据库迁移命令即可(两条一条不能少)
# 方式1 设置默认值
email = models.EmailField(default='123@qq.com') # varchar
# 方式2 允许字段为空
phone = models.BigIntegerField(null=True)
# 直接在提示中给默认值
gender = models.CharField(max_length=32)
字段的删除
直接注释掉对应的字段 然后再执行数据库迁移命令即可(谨慎使用)
模型表数据的增删改查
查(filter)
查单条数据
data = models.User.objects.filter(username=username) #括号内可以有多个值,是and关系
# <QuerySet [<User: User object>]>
"""
filter返回的结果是一个"列表",里面才是真正数据对象
filer括号内可以放多个关键字参数 这多个关键字参数在查询的时候 是and关系
"""
查询所有数据
user_list = models.User.objects.all() #等价于 models.User.objects.filter()
"""
结果是一个"列表" 里面是一个个的数据对象
"""
增(create)
user_obj = models.User.objects.create(username=username,password=password)
print(user_obj,user_obj.username,user_obj.password)
# create方法会有一个返回值 返回值就是当前被创建的对象本身
改(update)
models.User.objects.filter(id=edit_id).update(username=username,password=password)
"""
批量操作 会将filter查询出来的列表中所有的对象全部更新
"""
删(delete)
models.User.objects.filter(id=delete_id).delete()
"""
批量操作 会将filter查询出来的列表中所有的对象全部删除
"""
涉及知识点
form表单
请求
form表单默认是get请求
get请求也能够携带参数
http://127.0.0.1:8000/login/?username=jason&password=jason123
特点:url?xxx=xxx&yyy=yyy
1.携带的数据不安全
2.携带的数据大小有限制 最大好像应该差不多在4KB左右
3.通常只会携带一些不是很重要的数据
action
1.不写 默认朝当前地址提交
2.只写后缀 /index
3.写全路径 https://www.baidu.com
django中的orm
orm(对象关系映射)
类---->表
对象----->数据
对象点属性----->字段对应的值
使用orm可以把复杂的数据库操作封装起来,可以方便的去操作数据库
缺点:
封装程度太高,有时候会出现查询效率偏低的问题
魔法方法(内置方法)
#当类的对象被打印是会触发
def __str__(self):
return self.username