• 11.22


    静态文件配置

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

    什么是静态文件

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

    默认情况下网站所用到的静态文件资源全部会放在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'),  # 将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>
    

    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. 写全

    django前期在往后端提交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请求只想拿到页面,而post请求向提交数据给后端做校验

    判断请求方式

    request.method拿到的是大写的字符串形式的请求方式:GET POST

    request方法初识

    request.method 获取请求方式

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

    request.POST.get() 默认获取列表最后一个元素

    request.POST.getlist() 获取列表

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

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

    request.GET.getlist() 获取列表

    django连接MySQL

    必须要有两部操作

    1. 配置文件配置
    			DATABASES = {
    					'default': {
    						'ENGINE': 'django.db.backends.mysql',  # 指定数据库类型
    						'NAME': 'day49',  # 指定库的名字
    						'USER':'root',  # 注意 键必须是全大写
    						'PASSWORD':'',
    						'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

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

    orm的缺点

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

    如何操作orm

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

    数据库迁移命令

    python3 manage.py makemigrations  #将数据库的修改记录到migrations文件夹内
    python3 manage.py migrate  #将修改操作真正的同步到数据库中
    

    模型表字段的增删改查

    修改

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

    删除

    直接注释掉对应的字段,然后执行数据库迁移命令

    模型表数据的增删改查

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

    models.User.objects.filter(id=delete_id).delete()
    		"""
    			批量操作  会将filter查询出来的列表中所有的对象全部删除
    		"""
    
  • 相关阅读:
    【pandas】'Styler' object has no attribute 'highlight_between'
    【原创】3行代码搞定:Python批量实现多Excel多Sheet合并
    【挑战阿里面试题-10种方法实现DataFrame转list】
    SpringCloud+RocketMQ实现分布式事务
    分布式事物SAGA
    分布式事务TCC
    多线程学习——思维导图
    .NET CLI简单教程和项目结构
    使用Google Fonts注意事项
    如何在印刷品中使用遵循SIL Open Font License协议的字体
  • 原文地址:https://www.cnblogs.com/maqiaobin/p/11930324.html
Copyright © 2020-2023  润新知