wsgiref模块 web服务网关接口
帮你封装了socket
帮你处理http数据 直接封装成了一个大字典
也是flask的启动源码
django自带的模块 本身能够承受的并发量很低 大概1000左右
静态文件配置
1.默认情况下所有的html文件都是放在templates文件夹内
2.什么是静态文件
网站所使用的提前写的 css js 第三方的前端模块 图片 都叫做静态资源
3.默认情况下网站所用到的静态文件资源全部放在static文件夹下
通常情况下 在是static文件夹内部还会再键其他文件夹
css 文件夹
js 文件夹
font 文件夹
img 文件夹
bootstrap
font
STATIC_URL = '/static/' #访问静态文件资源接口的前缀 通常情况下接口前缀的名字也叫static
# 手动开设静态文件访问资源
STATICFILES_DIRS = [
os.path.join(BASE_DIR,'static') # 将static文件里面的所有的资源暴露给用户
] # 列表内可以添加多个路径,从上往下查找
4.静态文件动态绑定(************************)
{% 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>
注意: 浏览器有自动缓存功能,会导致有时你改过的页面加载没有更新,这里我们需要禁止浏览器使用缓存 F12找到settings(快捷键:F1)中的Network将Disable cache(while DevTools is open)勾选上
form表单默认是get请求
get请求也能够携带参数
http://127.0.0.1:8000/login/?username=jason&password=jason123
特点:url?xxx=xxx&yyy=yyy
1.携带的数据不安全
2.携带的数据大小有限制 最大差不多4kb
3.通常只携带一些不是很重要的数据
前期我们在朝后端提交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请求 都会执行视图函数
def login(request):
print('xxx')
return render(request,'login.html')
get请求指向拿到login页面
post请求想提交数据 然后后端做校验
如何判断当前请求方式
request.method #拿到的是字符串大写的请求方式 GET POST
def login(request):
# if request.method == 'GET':
# print('xxx')
# print(request.method,type(request.method)) # 获取前端请求方式
# return render(request,'login.html')
# elif request.method == 'POST':
# print('post业务逻辑')
# return HttpResponse('收到了')
if request.method == "POST":
return HttpResponse('收到了')
return render(request,'login.html')
request方法初识
request.method 获取请求方式 并且纯大写的字符串
request.POST 获取用户提交的post请求数据
如何获取用户数据
request.POST.get() # 默认只会获取列表最后一个元素
request.POST.getlist() # 如果你想获取列表 用getlist()
request.GET 获取用户提交的get请求数据
如何获取用户数据
request.GET.get() # 默认只会获取列表最后一个元素
request.GET.getlist() # 如果你想获取列表 用getlist()
pycharm连接数据库
django连接MySQL
必须有两步操作
1.配置文件配置
DATABASES = {
'default': {
'ENGINE': 'django.db.backends.mysql', # 指定数据库类型
'NAME': 'day49', # 指定库的名字
'USER':'root', # 注意 键必须是全大写
'PASSWORD':'123qwe',
'HOST':'127.0.0.1',
'PORT':3306,
'CHARSET':'utf8'
}
}
2.主动告诉django 不用默认的mysqldb连接 而是用pymysql
你可以在项目名下的 _init_.py 中书写
也可以在应用名下的 __init__.py 中书写
import pymysql
pymysql.install_as_MySQLdb()
django orm简介
orm 对象关系映射
类 表
对象 数据
对象点属性 字段对应的值
为什么使用orm
能让不会数据库操作的人也能够简单方便的去操作数据库
orm的缺点
封装程度太高 有时候会出现查询效率偏低的问题
所以工作中
简单的用 orm
复杂的 追求速度的 需要你手动书写sql语句
django中如何操作orm
书写模型类
去应用下的models.py中书写模型类(就是类)
之后再django项目的时候 一个django就对应一个数据库
不要出现多个项目使用同一个数据的情况
数据库迁移(同步)命令
1.python3 manage.py makemigrations # 将数据库的修改 记录到小本本上(migrations文件内)
2.python3 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)
字段的删除
直接注释掉对应的字段 然后再执行数据库迁移命令即可(谨慎使用)
模型表数据的增删改查
查
data = models.User.objects.filter(username=username) # <QuerySet [<User: User object>]>
"""
filter返回的结果是一个"列表",里面才是真正数据对象
filer括号内可以放多个关键字参数 这多个关键字参数在查询的时候 是and关系
"""
user_list = 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.objects.filter(id=edit_id).update(username=username,password=password)
"""
批量操作 会将filter查询出来的列表中所有的对象全部更新
"""
删(一般情况下不会使用)
models.User.objects.filter(id=delete_id).delete()
"""
批量操作 会将filter查询出来的列表中所有的对象全部删除
"""