zoukankan      html  css  js  c++  java
  • day 50小结

    wsgiref模块 web服务网关接口
    帮你封装了socket
    帮你处理http数据 直接封装成了一个大字典
    也是flask的启动源码
    django自带的模块 本身能够承受的并发量很低 大概1000左右

    静态文件配置

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

    ​ 2.什么是静态文件
    ​ 网站所使用的提前写的 css js 第三方的前端模块 图片 都叫做静态资源

    ​ 3.默认情况下网站所用到的静态文件资源全部放在static文件夹下
    ​ 通常情况下 在是static文件夹内部还会再键其他文件夹
    ​ css 文件夹
    ​ js 文件夹
    ​ font 文件夹
    ​ img 文件夹
    ​ bootstrap
    ​ font

    STATIC_URL = '/static/'		#访问静态文件资源接口的前缀	通常情况下接口前缀的名字也叫static
    # 手动开设静态文件访问资源
    STATICFILES_DIRS = [	
    	os.path.join(BASE_DIR,'static')  # 将static文件里面的所有的资源暴露给用户
    ]  # 列表内可以添加多个路径,从上往下查找
    

    ​ 4.静态文件动态绑定(************************)

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

    注意: 浏览器有自动缓存功能,会导致有时你改过的页面加载没有更新,这里我们需要禁止浏览器使用缓存 F12找到settings(快捷键:F1)中的Network将Disable cache(while DevTools is open)勾选上

    form表单默认是get请求

    ​ get请求也能够携带参数

    http://127.0.0.1:8000/login/?username=jason&password=jason123
    				特点:url?xxx=xxx&yyy=yyy
    

    ​ 1.携带的数据不安全
    ​ 2.携带的数据大小有限制 最大差不多4kb
    ​ 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请求 都会执行视图函数

    def login(request):
        print('xxx')
        return render(request,'login.html')
    

    ​ get请求指向拿到login页面
    ​ post请求想提交数据 然后后端做校验

    ​ 如何判断当前请求方式

    request.method	#拿到的是字符串大写的请求方式		GET POST
    def login(request):
        # if request.method == 'GET':
    				#     print('xxx')
    				#     print(request.method,type(request.method))  # 获取前端请求方式
    				#     return render(request,'login.html')
    				# elif request.method == 'POST':
    				#     print('post业务逻辑')
    				#     return HttpResponse('收到了')
    				if request.method == "POST":
    					return HttpResponse('收到了')
    				return render(request,'login.html')
    

    request方法初识

    ​ request.method 获取请求方式 并且纯大写的字符串

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

    request.POST.get()  # 默认只会获取列表最后一个元素
    			request.POST.getlist()  # 如果你想获取列表 用getlist()
    

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

    request.GET.get()  # 默认只会获取列表最后一个元素
    			request.GET.getlist()  # 如果你想获取列表 用getlist()
    

    pycharm连接数据库

    django连接MySQL
    ​ 必须有两步操作
    ​ 1.配置文件配置

    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
    能让不会数据库操作的人也能够简单方便的去操作数据库

    orm的缺点
    封装程度太高 有时候会出现查询效率偏低的问题
    所以工作中
    简单的用 orm
    复杂的 追求速度的 需要你手动书写sql语句

    django中如何操作orm
    书写模型类
    去应用下的models.py中书写模型类(就是类)

    之后再django项目的时候 一个django就对应一个数据库
    不要出现多个项目使用同一个数据的情况

    数据库迁移(同步)命令

    1.python3 manage.py makemigrations  # 将数据库的修改 记录到小本本上(migrations文件内)
    
    2.python3 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)
    

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

    模型表数据的增删改查

    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查询出来的列表中所有的对象全部删除
    """
    
  • 相关阅读:
    聊聊我在微软外服大数据分析部门的工作经历及一些个人见解
    WPF ScrollViewer(滚动条) 自定义样式表制作 (改良+美化)
    WPF Calendar 日历控件 样式自定义
    c# 委托 事件 lamda 简写
    WPF 启动唯一程序(项目,exe,实例)
    WPF 控件 深度克隆
    c# 枚举操作 正运算 逆运算
    WPF ScrollViewer(滚动条) 自定义样式表制作 图文并茂
    WPF查找子控件和父控件方法
    建立小型开发团队的工作协作:任务日历
  • 原文地址:https://www.cnblogs.com/LZF-190903/p/11923385.html
Copyright © 2011-2022 走看看