Django框架基础

目录

一.小白必会三板斧

二.全局配置文件

三.静态文件的配置

1.哪些是静态文件

2.静态文件存在Django框架的哪个位置

3.动态解析

四.request对象的方法

五.操作数据库

1.连接数据库

2..Django连接数据库

[六.Django ORM](#六.Django ORM)

1.在models.py中建表

2.数据库迁移命令


一.小白必会三板斧

  • HttpResponse:返回字符串类型的数据

  • render:返回html文件

  • redirect:重定向目标网址

python 复制代码
def index(request):
    print('request')
    # return HttpResponse("resquest")         # 返回的是字符串
    # return render(request,'index.html')     # 加载HTML页面的
    # return redirect('http://www.baidu.com') # 加载HTML页面的
    # return redirect('/home/')               # 重定向的

二.全局配置文件

python 复制代码
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', # 这是全写
]

三.静态文件的配置

1.哪些是静态文件

直接拿来使用的都是静态文件,像是HTML文件、CSS文件、JS文件等

2.静态文件存在Django框架的哪个位置

我们一般把静态文件放在框架下的static文件夹,但是,默认情况下没有这个文件夹,因此,需要我们手动创建出来这个文件夹static

静态的html一般放在templases文件夹下
一般我们会在static文件夹下进一步划分目录:

CSS

JS

img

...

在浏览器中输入url能够看到对应的资源是因为后端提前开设了相关的接口,如果访问不到资源,说明后端没有开设相关资源的端口

3.动态解析

{% %} 一般写跟逻辑相关的

{{ }} 一般写跟变量相关的

python 复制代码
{% 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提交表单,前期先把下面的代码注释掉

python 复制代码
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',
]

print(request.GET)

print(request.GET.get('a'))

print(request.GET.get('b'))

print(request.GET.get('c'))

print(request.GET.getlist('c'))

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请求方式提交的表单数据

request.method == 'POST':

五.操作数据库

1.连接数据库

修改数据库配置

python 复制代码
DATABASES = {
    'default': {
        'ENGINE': 'django.db.backends.mysql',
        'NAME': 'day09',
        'USER': 'root',
        'PASSWORD': '1314521',
        'HOST': '127.0.0.1',
        'PORT': 3306,
        'CHARSET': 'utf8',
    }
}

代码声明: django 默认使用mysqldb模块链接mysql,但是该模块的兼容性不好,需要手动修改为pymysql链接

2..Django连接数据库

配置完链接数据的代码之后,Django默认启动不起来了,原因是:内部使用的链接模块用的是mysqldb

我们不使用这个模块,我们使用pymysql模块

如何更换pymysql

在任意的__init__.py文件中添加一下代码

import pymysql

pymysql.install_as_MySQLdb()

后续还有一个模块:mysqlclient

这个模块不需要加任何代码。但是,这个模块不容易装上,易报错

六.Django ORM

ORM --- 对象映射关系

作用:能够让一个不会用sql语句操作数据库的小白也能通过python面向对象的代码简单快捷的操作数据库

不足之处:封装程度高,sql语句效率低

类名 ------> 表名

对象 ------> 一条记录

属性 ------> 一个字段

1.在models.py中建表

python 复制代码
from django.db import models


# Create your models here.

class User(models.Model):
    # id int primary key auto_increment
    id = models.AutoField(primary_key=True)

    # username varchar(32)
    username = models.CharField(max_length=32)

    # password int
    password = models.IntegerField()

2.数据库迁移命令

  • 将操作记录记录在migrations文件夹,生成迁移记录
python 复制代码
python39 manage.py makemigrations
  • 将操作同步到真正的数据库,生成表
python 复制代码
python39 manage.py migrate
相关推荐
coderWangbuer6 分钟前
基于springboot的高校招生系统(含源码+sql+视频导入教程+文档+PPT)
spring boot·后端·sql
无限大.10 分钟前
c语言200例 067
java·c语言·开发语言
余炜yw11 分钟前
【Java序列化器】Java 中常用序列化器的探索与实践
java·开发语言
攸攸太上12 分钟前
JMeter学习
java·后端·学习·jmeter·微服务
篝火悟者13 分钟前
问题-python-运行报错-SyntaxError: Non-UTF-8 code starting with ‘\xd5‘ in file 汉字编码问题
开发语言·python
Kenny.志15 分钟前
2、Spring Boot 3.x 集成 Feign
java·spring boot·后端
Death20015 分钟前
Qt 中的 QListWidget、QTreeWidget 和 QTableWidget:简化的数据展示控件
c语言·开发语言·c++·qt·c#
六点半88817 分钟前
【C++】速通涉及 “vector” 的经典OJ编程题
开发语言·c++·算法·青少年编程·推荐算法
惜.己17 分钟前
javaScript基础(8个案例+代码+效果图)
开发语言·前端·javascript·vscode·css3·html5
niu_sama20 分钟前
基于muduo库函数实现protobuf协议的通信
开发语言·qt