• django初识


    静态文件

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

    什么是静态文件

    网站所使用的提前写的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 %}
        <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=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')
    
    1. request.method 获取请求方式,得到纯大写的字符串 GET POST

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

      request.POST.get('username')    # 默认只取列表最后一个元素
      request.POST.getlist('username')   # 获取列表
      
    3. 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)  # <QuerySet [<User: User object>]>
    # 相当于 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查询出来的列表中所有的对象全部删除
    """
    
  • 相关阅读:
    python-web自动化环境安装
    python-单元测试优化,加入日志
    小谢第17问:三目运算符嵌套使用方法
    小谢第16问:1到6000的正整数正则表达式怎么写?
    小谢第15问:5到60的正整数正则表达式怎么写?
    小谢第14问:多个if语句和else if有什么区别?
    小谢第13问:输入框绑定回车enter事件自动刷新页面
    小谢第12问:初始化页面的时候子组件为什么不渲染?
    小谢第11问:vue中,子组件获取的值怎么传给父组件
    小谢第10问:前端JS下载文件、表格
  • 原文地址:https://www.cnblogs.com/setcreed/p/11924031.html
Copyright © 2020-2023  润新知