三板斧的使用
三个方法:
1.HttpResponse
2.render
3.redirect
def index(request):
print('request')
# return HttpResponse("request") # 它返回的是字符串
# return render(request, 'index.html') # 渲染HTML页面
# return redirect('http://www.baidu.com')
return redirect('/home/') # 重定向
全局配置文件
LANGUAGE_CODE = 'zh-hans'
TIME_ZONE = 'Asia/Shanghai'
USE_I18N = True
USE_L10N = True
USE_TZ = False
DATABASES = {
'default': {
'ENGINE': 'django.db.backends.sqlite3',
'NAME': os.path.join(BASE_DIR, 'db.sqlite3'),
}
}
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',
]
INSTALLED_APPS = [
'django.contrib.admin',
'django.contrib.auth',
'django.contrib.contenttypes',
'django.contrib.sessions',
'django.contrib.messages',
'django.contrib.staticfiles',
'app01.apps.App01Config', # 这是全写
]
静态文件的配置
静态文件:
类似于HTML文件
类似于CSS文件
类似于js文件
图片
第三方的前端框架(jQuery、bootstrap)
...
# 直接拿来就使用的都是静态文件的
# 静态文件存在Django框架的哪个位置?
"""
我们一般把静态文件放在框架下的static文件夹,但是,默认情况下没有这个文件夹,因此,需要我们手动创建出来这个文件夹static
静态的html一般放在templaes文件夹下面
"""
# 我们一般还会在static文件夹下进一步的划分目录
css
js
img
...
/index
/home
"""我们访问不到一个地址,是因为在Django里面没有开设这样一个地址,Django帮你加了,你只需要按照我的规则添加即可"""
http://127.0.0.1:8000/static/bootstrap-3.4.1-dist/css/bootstrap.min.css
{% %} # 一般写跟逻辑相关的
{{ }} # 跟变量相关的
## 动态解析
{% load static %}
<script src="{% static 'js/jquery_3.7.1_jquery.min.js' %}"></script>
<link rel="stylesheet" href="{% static 'bootstrap-3.4.1-dist/css/bootstrap.min.css' %}">
<script src="{% static 'bootstrap-3.4.1-dist/js/bootstrap.min.js' %}"></script>
"""这个配置是访问静态文件的令牌"""
STATIC_URL = '/dasdasdasdas/'
"""其实就是static文件夹的路径"""
STATICFILES_DIRS = [
os.path.join(BASE_DIR, 'static'),
os.path.join(BASE_DIR, 'static1'),
os.path.join(BASE_DIR, 'static2')
]
request对象的方法
<form action="" method="post">
action:
1. 不写,朝当前地址提交
2. 全写
3. 只写后缀
# post提交表单,前期先把下面的代码注释掉
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',
]
127.0.0.1/index/?a=1&b=2&c=3
print(request.GET) # <QueryDict: {'a': ['1'], 'b': ['2'], 'c': ['3']}>
print(request.GET.get('a')) # 1
print(request.GET.get('b')) # 2
print(request.GET.get('c')) # 3
print(request.GET.getlist('c')) # ['3']
# print(request.POST) # 获取以post请求方式提交的表单数据
# print(request.POST.get('username')) # kevin 获取以post请求方式提交的表单数据
# print(request.POST.get('password')) # 123 获取以post请求方式提交的表单数据
"""get获取默认拿到的是最后一个元素值"""
# print(request.POST.get('hobby')) # 3 获取以post请求方式提交的表单数据
# ['a', 'b', 'c']
username = request.POST.get('username')
password = request.POST.get('password')
print(request.POST.getlist('hobby')) # 3 获取以post请求方式提交的表单数据
django连接数据库
配置完链接数据的代码之后,Django默认启动不起来了,原因是:内部使用的链接模块用的是mysqldb
我们不使用这个模块,我们使用pymysql模块
# 如何更换pymysql
在任意的__init__.py文件中添加一下代码
import pymysql
pymysql.install_as_MySQLdb()
# 后续还有一个模块:mysqlclient,这个模块不需要加任何的代码
这个模块一般装不上,不容易装上,很容易报错
orm介绍
orm: 对象映射模型
在Django中操作数据库就不用在写原生的SQL语句,而是使用面向对象的语法和一些方法来操作数据库
缺点:代码的封装程度太高,导致的问题:执行效率下降了,目前可以忽略,需要自己写原生SQL语句
类名 >>> 表名
对象 >>> 一条记录
属性 >>> 一个字段
## 我们的这些orm在哪里书写呢?
models.py这个文件就是跟数据库打交道的
## 类名写好之后,一定别忘了做数据库迁移命令
***************************************************************************************
python manage.py makemigrations # 生成迁移的记录(类似以是一个小本本)
python manage.py migrate # 这句话才是真正的操作了数据库,然后生成表
"""当你修改了跟数据量相关的代码之后,都要执行这两句话"""
***************************************************************************************
数据的增删改查
# views.py
from django.shortcuts import render, HttpResponse, redirect, reverse
from app01 import models
from django.views import View
# 注册功能
def regi(request):
if request.method == 'POST':
user = models.UserInfo.objects.filter(username=request.POST['username'])
if request.POST['username'] and request.POST['password']:
if not user:
models.UserInfo.objects.create(username=request.POST['username'], password=request.POST['password'])
return HttpResponse('注册成功')
return HttpResponse('用户名已存在,请勿重复注册')
return HttpResponse('用户名或密码不能为空')
return render(request, 'regi.html')
# 登录功能
def login(request):
if request.method == 'POST':
if request.POST['username'] and request.POST['password']:
users = models.UserInfo.objects.filter(username=request.POST['username']).filter(password=request.POST['password']).first()
if users:
return HttpResponse('登录成功')
return HttpResponse('用户名或密码错误')
return HttpResponse('用户名或密码不能为空')
return render(request, 'login.html')
# 用户列表的展示
def userlist(request):
userlist = models.UserInfo.objects.all()
return render(request, 'userlist.html', locals())
# 修改功能
def edit(request, id):
edit_obj = models.UserInfo.objects.filter(id=id).first()
if request.method == 'POST':
hidden_id = request.POST['edit_id']
username = request.POST.get('username')
password = request.POST.get('password')
gender = request.POST.get('gender')
models.UserInfo.objects.filter(id=hidden_id).update(username=username, password=password, gender=gender)
return redirect('/userlist/')
return render(request, 'edit.html', locals())
# 删除功能
def delete(request):
del_id = request.GET['id']
models.UserInfo.objects.filter(id=del_id).delete()
return redirect('/userlist/')
# 增加功能
def add(request):
if request.method == 'POST':
username = request.POST['username']
password = request.POST['password']
gender = request.POST['gender']
models.UserInfo.objects.create(username=username, password=password, gender=gender)
return redirect('/userlist/')
return render(request, 'add.html')
# 注册页面
<div class="container">
<div class="row">
<h1 class="text-center">注册页面</h1>
<form action="" method="post">
<div class="form-group">
用户名:<input type="text" class="form-control" name="username">
</div>
<div class="form-group">
密码:<input type="password" class="form-control" name="password">
</div>
<div class="form-group">
<input type="submit" class="btn btn-success btn-block" value="注册">
</div>
</form>
</div>
</div>
# 登录页面
<div class="container">
<div class="row">
<form action="" method="post">
<h1 class="text-center">登录页面</h1>
<div class="form-group">
<input type="text" class="form-control" placeholder="请输入用户名" name="username">
</div>
<div class="form-group">
<input type="password" class="form-control" placeholder="请输入密码" name="password">
</div>
<div class="form-group">
<input type="submit" class="btn btn-block btn-success" value="登录">
</div>
</form>
</div>
</div>
# 用户列表展示页面
<div class="container">
<div class="row">
<h1 class="text-center">用户列表</h1>
<a href="/add/" class="btn btn-success btn-group">添加用户</a>
<table class="table table-striped table-hover table-bordered">
<thead>
<tr>
<th>ID</th>
<th>用户名</th>
<th>密码</th>
<th>性别</th>
<th>操作</th>
</tr>
</thead>
<tbody>
{% for user in userlist %}
<tr>
<td>{{ user.id }}</td>
<td>{{ user.username }}</td>
<td>{{ user.password }}</td>
<td>{{ user.gender }}</td>
<td>
<a href="{% url 'edit_id' user.id %}" class="btn btn-success">修改</a>
<a href="/delete/?id={{ user.id }}" class="btn btn-success">删除</a>
</td>
</tr>
{% endfor %}
</tbody>
</table>
</div>
</div>
# 修改页面
<div class="container">
<div class="row">
<h1 class="text-center">修改页面</h1>
<form action="" method="post">
<input type="hidden" name="edit_id" value="{{ edit_obj.id }}">
<div class="form-group">
用户名:<input type="text" name="username" class="form-control" value="{{ edit_obj.username }}">
</div>
<div class="form-group">
密码:<input type="password" name="password" class="form-control" value="{{ edit_obj.password }}">
</div>
<div class="form-group" name="gender">
性别:<input type="text" class="form-control" value="{{ edit_obj.gender }}" name="gender">
</div>
<div>
<input type="submit" class="btn btn-block btn-success" value="提交">
</div>
</form>
</div>
</div>
# 增加页面
<div class="container">
<div class="row">
<h1 class="text-center">添加数据</h1>
<form action="" method="post">
<div class="form-group">
用户名:<input type="text" class="form-control" name="username">
</div><div class="form-group">
密码:<input type="password" class="form-control" name="password">
</div>
<div class="form-group">
性别:<input type="text" class="form-control" name="gender">
</div>
<div class="form-group">
<input type="submit" class="btn btn-success" value="提交">
</div>
</form>
</div>
</div>
创建表关系
"""
一对一 OneToOneField
一对多 ForeignKey
多对多 ManyToManyField
没有关系
"""
图书表
出版社表
作者表
作者详情表
### 换位思考法判断表关系
图书表和出版社表 >>> 一对多 >>> 图书表是多,出版社是一 >>> 建在多的一方
图书表和作者表 >>> 多对多 >>> 需要第三张表
作者表和作者详情表 >>> 一对一 >>> 外键字段一般建在查询频率较高的
### 在Django中如何创建表关系
"""回头复习表关系"""
#######################################django1.x#######################################
class Book(models.Model):
title = models.CharField(max_length=64)
"""
max_digits=None,:总位数
decimal_places=None:小数位数
"""
# price decimal(8,2)
price = models.DecimalField(max_digits=8, decimal_places=2)
# publish_id = models.ForeignKey(to='Publish', to_field='id')
"""对于外键字段关系,会自动帮我们拼接_id"""
publish = models.ForeignKey(to='Publish')
"""authors它是一个虚拟字段,它不会实际在表中创建出来这个字段,这一句可以自动帮助我们创建出来第三张表"""
authors = models.ManyToManyField(to='Author')
"""出版社表"""
class Publish(models.Model):
name = models.CharField(max_length=64)
addr = models.CharField(max_length=64)
"""作者表"""
class Author(models.Model):
name = models.CharField(max_length=64)
author_detail = models.OneToOneField(to='AuthorDetail')
"""作者详情表"""
class AuthorDetail(models.Model):
phone = models.CharField(max_length=64)
email = models.CharField(max_length=64)