• Django(二)


    Django(二)

    静态文件配置

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

    2. 静态文件

      网站所使用的css,js,第三方的模块,图片都叫做静态资源

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

    在Django中,需要我们自己创建static静态文件夹,用于存放静态文件

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

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

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

    中间件

    ​ 朝后端提交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',
    ]
    

    method

    浏览器通过哪种请求方式来访问的,可以通过request.method获取

    #request.method  拿到的是字符串大写的请求方式(GET,POST)
    def login(request):
        if request.method == "POST":
            return HttpResponse('收到了')
        return render(request,'login.html')
    

    request方法

    request方法初识
        request.method  获取请求方式  并且纯大写的字符串
        
        request.POST    获取用户提交的post请求数据
        如何获取用户数据(******)
            request.POST.get()  # 默认只会获取列表最后一个元素
            request.POST.getlist()  # 如果你想获取列表 用getlist()
        request.GET     获取用户提交的get请求数据
        
        如何获取用户数据(******)
            request.GET.get()  # 默认只会获取列表最后一个元素
            request.GET.getlist()  # 如果你想获取列表 用getlist()
    

    django连接MySQL

    django连接MySQL分为两个步骤:

    1. 配置文件配置
    DATABASES = {
        'default': {
            'ENGINE': 'django.db.backends.mysql',	# 指定数据库类型
            'NAME': 'django',	# 指定库的名字
            'USER':'root',
            'PASSWORD':'123',
            'HOST':'127.0.0.1',
            'PORT':3306,
            'CHARSET':'utf8',
        }
    }
    #键必须是全大写  
    
    1. 设置默认数据库连接的模块

      django默认用mysqldb连接,需要换成pymysql

      #可以在项目名下的__init__.py中书写
      #也可以在应用名下的__init__.py中书写
      import pymysql
      pymysql.install_as_MySQLdb()
      

    在Django中操作orm

    在应用下的models.py文件中书写模型类

    # 1. AutoField ---> 自动递增
    # 2. CharField ---> 字符串
    # 3. IntegerField ---> 数字型
    
    class User(models.Model):
        #如果不指定主键,会自动创建一个id字段作为主键
        #如果手动指定了主键,则django将不会再自动创建
        id = models.AutoField(primary_key=True)
        username = models.CharField(max_length=32)
        password = models.CharField(max_length=32)
    

    数据库迁移(同步)命令

    # 1. python manage.py makrmigrations  
    	#将数据库的修改先记录到migrations文件内,此时数据库中的数据不发生改变
    # 2. python manage.py migrate
    	#将修改操作真正的同步到数据库中
        
    #上面两条命令必须是成双成对出现
    	#只要修改了models里面跟数据库相关的代码  你就必须重新执行上面两条命令
    

    模型表字段的增删改

    注意:

    ​ 只要对表字段作了增删改,都需要去执行数据库迁移命令,两条命令一条不能少

    字段的修改
        直接修改代码 然后执行数据库迁移命令即可(两条一条不能少)
            # 方式1  设置默认值
            email = models.EmailField(default='123@qq.com')  # varchar
            # 方式2   允许字段为空
            phone = models.BigIntegerField(null=True)
            # 直接在提示中给默认值
            gender = models.CharField(max_length=32)
    字段的删除
        直接注释掉对应的字段 然后再执行数据库迁移命令即可(谨慎使用)
    

    模型表数据的增删改查

    查(filter)

    查单条数据

    data = models.User.objects.filter(username=username) #括号内可以有多个值,是and关系
    # <QuerySet [<User: User object>]>
    		"""
    		filter返回的结果是一个"列表",里面才是真正数据对象
    		filer括号内可以放多个关键字参数 这多个关键字参数在查询的时候 是and关系
    		"""
    

    查询所有数据

    user_list = models.User.objects.all()  #等价于 models.User.objects.filter()
    		"""
    		结果是一个"列表" 里面是一个个的数据对象
    		"""
    

    增(create)

    user_obj = models.User.objects.create(username=username,password=password)
    print(user_obj,user_obj.username,user_obj.password)
    # create方法会有一个返回值  返回值就是当前被创建的对象本身
    

    改(update)

    models.User.objects.filter(id=edit_id).update(username=username,password=password)
    """
    批量操作  会将filter查询出来的列表中所有的对象全部更新
    """
    

    删(delete)

    models.User.objects.filter(id=delete_id).delete()
    """
        批量操作  会将filter查询出来的列表中所有的对象全部删除
    """
    

    涉及知识点

    form表单

    请求

    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.只写后缀 /index
    3.写全路径 https://www.baidu.com
    

    django中的orm

    orm(对象关系映射)

    类---->表

    对象----->数据

    对象点属性----->字段对应的值

    使用orm可以把复杂的数据库操作封装起来,可以方便的去操作数据库

    ​ 缺点:

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

    魔法方法(内置方法)

    #当类的对象被打印是会触发
    def __str__(self):
        return self.username
    
  • 相关阅读:
    OCP-1Z0-051-V9.02-108题
    以一种访问权限不允许的方式做了一个访问套接字的尝试
    常用的几个官方文档
    OCP-1Z0-053-V12.02-388题
    FusionChart实现奇偶间隔显示
    OCP-1Z0-053-V12.02-138题
    Tcp and Udp NAT 穿越穿透打洞
    flashback database实验(使用lgmnr找出还原时间点)
    flashback table实验(基于undo数据)
    flashback query实验(基于undo数据)
  • 原文地址:https://www.cnblogs.com/samoo/p/11922516.html
Copyright © 2020-2023  润新知