静态文件

默认情况下所有的html文件都是放在templates文件夹内

django初识(django基础知识)

什么是静态文件

网站所使用的提前写的css、js 第三方的前端模块、图片都叫做静态资源

默认情况下网站使用的静态资源全部会放到static文件夹下

通常情况下 在static文件夹内部还会再建其他文件夹 这是为了更加方便地管理文件,在django中 需要你自己手动创建静态文件存放的文件夹

css 文件夹

js 文件夹

font 文件夹

img 文件夹

Bootstrap

注意点:视图函数都必须有返回值,并且返回值都是HttpResponse对象

静态文件的配置

django后端如果想要暴露后端资源,必须去urls里面开设对应的资源接口

在项目文件夹下settings.py配置:

STATIC_URL = '/static/' # 访问静态文件资源接口前缀

# 手动开设静态文件访问资源

STATICFILES_DIRS = [ # 静态资源所在的文件所i在文件夹路径

os.path.join(BASE_DIR, 'static'), # 将static里面的所有资源暴露给用户

os.path.join(BASE_DIR, 'static1') # static找不到会往下找,逐层找

]

静态文件动态绑定

{% load static %}

注意事项

form表单默认是get请求,get请求也能够携带参数

格式:http://127.0.0.1:8000/login/?username=cwz&password=123

特点:

携带的数据不安全

携带的数据大小有限制

通常只会携带一些不是很重要的数据

前期在朝后端提交post请求出现403的情况,需要在配置文件中注释掉一行内容:

'django.middleware.csrf.CsrfViewMiddleware',

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',

]

request方法初识

在django中后端的视图函数,无论是发的get请求还是post请求,都会执行视图函数,默认处理的是get请求。

get请求指向拿到login页面

post请求想提交数据,然后后端做校验

判断当前请求方式:

利用request.method 拿到的字符串大写的请求方式

def login(request):

# print('哈哈哈')

# print(request.method)

# print(type(request.method))

if request.method == 'POST':

return HttpResponse('收到了')

return render(request, 'login.html')

request.method 获取请求方式,得到纯大写的字符串 GET POST

request.POST 获取用户提交的post请求数据

request.POST.get('username') # 默认只取列表最后一个元素

request.POST.getlist('username') # 获取列表

request.GET 获取用户提交的get请求数据

request.GET.get() # 默认只会获取列表最后一个元素

request.GET.getlist() # 如果你想获取列表 用getlist()

pycharm连接数据库

pycharm也可以充当MySQL的客户端

django连接MySQL

django默认的数据库是sqlite3,我们改为MySQL,需要两步操作

在配置文件中改数据库的配置:

DATABASES = {

'default': {

'ENGINE': 'django.db.backends.mysql', # 指定数据库

'NAME': 'test', # 指定库的名字

'HOST': '127.0.0.1', # 要注意键必须大写

'PORT': 3306,

'USER': 'root',

'PASSWORD': '123',

'CHARSET': 'utf8'

}

}

主动告诉django 不要用默认的mysqldb连接 而是用pymysql

# 你可以在项目名下的__init__.py中书写

# 也可以在应用名下的__init__.py中书写

import pymysql

pymysql.install_as_MySQLdb()

django ORM简介

ORM 对象关系映射

对象

数据

对象.属性

字段对应的值

为什么使用ORM

能够让不会数据库操作的人也能够简单方便去操作数据库

缺点:

封装程度太高 有时候会出现查询效率偏低的问题

django中操作ORM

去应用下的models.py中写数据模型类

class User(models.Model):

# id = models.AutoField(primary_key=True)

# django当你不指定主键的时候,会自动帮你创建一个名为id字段,并作为主键

# 如果你自己指定了主键 django就不会再帮你创建

# 对应的是varchar(32) django中默认没有char字段,但支持用户自定义

username = models.CharField(max_length=32)

password = models.IntegerField()

数据库迁移命名(同步)

python manage.py makemigrations 将数据库的修改 记录到小本本上(migrations文件夹内)

python manage.py migrate 将修改操作真正的同步到数据库中

注意:

- 上面两条命令必须是成双成对出现

- 只要修改了models里面跟数据库相关的代码 你就必须重新执行上面两条命令

模型表字段的增删改查

字段的修改

直接修改代码 然后执行数据库迁移命令即可

新增字段,

方式1 设置默认值

email = models.EmailField(default='123@qq.com')

方式2 允许字段为空

phone = models.BigIntegerField(null=True)

方式3 直接在提示中给默认值

字段的删除

直接注释掉对应的字段,然后执行数据库迁移命令(谨慎使用)

模型表数据的增删改查

data = models.User.objects.filter(username=username) # ]>

# 相当于 select * from user where username='neo'

"""

filter返回的结果是一个"列表",里面才是真正数据对象

filer括号内可以放多个关键字参数 这多个关键字参数在查询的时候 是and关系

"""

user_list = models.User.objects.all()

"""

结果是一个"列表",里面是一个个的数据对象

"""

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查询出来的列表中所有的对象全部删除

"""