首页 > 数据库技术 > 详细

11.22 django和数据库、html页面之间的操作

时间:2019-11-25 00:28:37      阅读:113      评论:0      收藏:0      [点我收藏+]

静态文件配置:

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

  • 什么是静态文件:网站所使用到的提前写的CSS、js、 第三方的前端模块 图片 都叫静态资源

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

    • 通常情况下 在static文件夹内部还会再建其他文件夹
      • CSS 文件夹
      • js 文件夹
      • font 文件夹
      • img 文件夹
      • Bootstrap
      • fontawesome
    • django中 需要自己手动创建静态文件存放的文件夹
  • STATIC_URL = ‘/static/‘ #访问静态文件资源接口前缀 通常情况下接口前缀的名字也叫static

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

    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.携带的数据大小有限制

    3.通常只会携带一些不是很重要的数据

  • action

? 1.不写 默认朝当前地址提交

? 2.只写后缀/index

? 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('来啦 老弟~')
    return render(request,'login.html')

get请求只想拿到login页面

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

  • 如何判断当前请求方式
request.method 拿到的是字符串大写的请求方式  GET POST

def login(request):
    # if request.method == 'GET':
    #     print('来啦 老弟~')
    #     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

    • 书写模型类

    • 去应用下的model.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查询出来的列表中所有的对象全部删除
        """

11.22 django和数据库、html页面之间的操作

原文:https://www.cnblogs.com/lidandanaa/p/11924948.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!