Django的基本使用

三板斧的使用

三个方法:
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>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;
                    <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)

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值