zoukankan      html  css  js  c++  java
  • Day 50 Django静态文件配置/连接数据库/ORM操作

    静态文件配置

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

    2. 什么是静态文件

      网站所使用到的提前写的css,js,第三方模块,图片都叫做静态文件

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

      通常情况下,在static文件夹内部还会再建其他文件夹

      ​ css 文件夹

      ​ js 文件夹

      ​ font 文件夹

      ​ img 文件夹

      ​ Bootstrap

      ​ fontawesome

      ​ 为了更加方便的管理文件

      django中需要你手动创建静态文件存放的文件夹

    STATIC_URL = '/static/'  # 访问静态文件资源的接口前缀,通常情况下接口前缀的名字也叫static
    
    # 手动开设静态文件访问资源
    STATICFILES_DIRS = [  # 静态资源所在的文件夹路径
        os.path.join(BASE_DIR, 'static'),  # 将static文件里面所有的资源暴露给用户
        os.path.join(BASE_DIR, 'static1'),  # 将static1文件里面所有的资源暴露给用户
    ]
    
    1. 静态文件动态绑定

      {% 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>
      

    请求方式

    form表单默认是get请求

    ​ get请求也能够携带参数

    http://127.0.0.1:8000/login/?username=jason&password=jason123

    ​ 特点:url?xxx=xxx&yyy=yyy

    	1. 携带的数据不安全
    	2. 携带的数据大小有限制,最大好像应该差不多是4KB
    	3. 通常只会携带一些不是跟重要的数据
    

    action

    1. 不写默认朝当前地址提交
    2. 只写后缀
    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请求 都是执行视图函数

    get请求指向拿到login页面

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

    request方法初识

    request.method 获取请求方式,并且以纯大小的字符串表示

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

    # 如何获取用户数据
    request.POST.get()  # 默认只会获取列表最后一个参数
    request.GET.getlist()  # 获取一个列表
    

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

    # 如何获取用户数据
    request.GET.get()  # 默认只会获取列表最后一个参数
    request.GET.getlist()  # 获取列表
    

    Django连接数据库

    必须要有两步操作

    1. settings文件的配置

      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

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

    缺点

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

    Django orm操作

    django中如何操作orm

    书写模型类

    去应用下的models.py中书写模型类(就是类)

    数据库迁移命令

    1. python manage.py makemigrations # 将数据库的修改,记录到migration文件内
    2. python manage.py migrate # 将修改操作真正的同步到数据库上

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

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

    模型表字段的增删改查

    字段的修改

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

    方式一:

    设置默认值

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

    方式二:

    设置可以为Null

    phone = models.CharField(null=True)
    

    字段的删除

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

    模型表数据的增删改查

    data = models.User.objects.filter(username='')  ## <QuerySet [<User: User object>]>
    ​```
    filter返回的结果是一个"列表",里面才是真正的对象
    filter括号内可以放多个关键字参数,这多个关键字参数在查找的时候是'and'关系
    ​```
    data = 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.object.filter(id=1).update(username='',)
    # 批量操作  会将filter查询出来的列表中所有的对象全部更新
    

    删(一般情况下不会使用)

    models.User.objects.filter(id=delete_id).delete()
    # 批量操作  会将filter查询出来的列表中所有的对象全部删除
    
  • 相关阅读:
    树:二叉树
    树:红黑树
    gtest
    VDB R&D
    QML 从入门到放弃
    json parse
    Effective C++ 笔记
    Samples topic
    C++ 11 snippets , 2
    C++ 11 snippets , 1
  • 原文地址:https://www.cnblogs.com/2222bai/p/11927623.html
Copyright © 2011-2022 走看看