zoukankan      html  css  js  c++  java
  • 小白必会三板斧、静态文件配置、request对象及方法、pycharm和django连接数据库、字段的增删改查和数据的增查

    1021 小白必会三板斧、静态文件配置、request对象及方法、pycharm和django连接数据库、字段的增删改查和数据的增查

    一、三板斧

    用户能够访问到的所有资源吗,都是程序员提前暴露好的,如果没有暴露,用户就永远访问不了

    django是可以自动重启的,但是有时候反映速度比较慢,也有可能在你代码没写完的时候重启

    三板斧需要导入:from django.shortcuts import render,HttpResponse,redirect

    HttpResponse(返回字符串)

    render(返回html页面)

    redirect(重定向)

    二、静态文件配置

    静态文件

    网站所用到的自己写好的js、自己写好的css、第三方的框架bootstrap、fontawesome、sweetalert

    通常情况下,网站所用到的静态文件资源,统一都放在static文件夹下

    STATIC_URL = '/static/' # 是访问静态资源的接口前缀
    """只要你想访问静态资源 你就必须以static开头"""
    手动配置静态文件访问资源
    STATICFILES_DIRS = [
    os.path.join(BASE_DIR,'static'),
    os.path.join(BASE_DIR,'static1'),
    os.path.join(BASE_DIR,'static2'),
    ]

    接口前缀的动态解析

    <head>
        <meta charset="UTF-8">
        <title>Title</title>
        <script src="https://cdn.bootcss.com/jquery/3.4.1/jquery.min.js"></script>
    {#    <link rel="stylesheet" href="/static/bootstrap/css/bootstrap.css">#}
    {#    <script src="/static/bootstrap/js/bootstrap.js"></script>#}
    {#    这种注释不会在页面显示#}    <!--这种注释会在页面显示-->
    {#    静态文件的动态解析#}  
        {% load static %}
        <link rel="stylesheet" href="{% static 'bootstrap/css/bootstrap.min.css' %}">
        <script src="{% static 'bootstrap/js/bootstrap.min.js' %}"></script>
    </head>
    

    form表单的action参数可以写的形式

    1. 不写,默认朝当前地址提交
    2. 只写后缀/index/
    3. 写全路径

    form表单默认朝后端提交的方式,默认是get请求,可以在class属性的method修改为post,就可以改为post请求。

    ​ get请求携带参数的方式,是在url后面?

    ​ url?username=admin&password=213213213213213

    ​ 缺点:

    ​ 1.不安全

    ​ 2.get请求携带的参数有大小限制(最大不能超过4KB左右)

    前期如果要提交post请求,得去settings的MIDDLEWARE中注释掉一个中间件

    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对象及方法

    前后端数据交互

    如何获取请求方式:request.method

    获取post请求携带的数据:request.POST

    获取get请求携带的数据:request.GET

    get和post在后端获取用户数据的时候,规律是一样的

    <QueryDict: {'username': ['admin', 'tank'], 'password': ['123']}>
    tank <class 'str'>
    123 <class 'str'>
    request.POST.get('username') 默认只取列列表的最后一个元素
    如果你想将列表完整的取出 你必须用getlist()

    四、pycharm连接数据库和django连接数据库

    pycharm连接数据库

    点击窗口右侧的database,选择MySQL,选择要连接的库名,输入用户名和密码,点击apply,ok就可以

    django连接数据库

    第一步:要到settings.py文件中配置,在DATABASES中修改

    DATABASES = {
        'default': {
            'ENGINE': 'django.db.backends.mysql',  # 指定数据库 MySQL postgreSQL
            'NAME': 'getdb',  # 到底使用哪个库
            'USER': 'root',
            'PASSWORD': 'root',
            'HOST': '127.0.0.1',
            'PORT': 3306,
            'CHARSET': 'UTF8'
        }
    }
    

    第二步 :django默认使用的是mysqldb连接数据库,但是该模块不支持,所以你要告诉django不要用mysqldb,要改用pymysql连接

    # 你可以在项目名下面的__init__.py也可以在应用名下面的__init__.py文件中指定
    import pymysql
    pymysql.install_as_MySQLdb()
    

    五、django orm简介

    orm:对象关系映射

    ​ 类---------------------------数据库的表

    ​ 对象------------------------表的记录

    ​ 对象获取属性------------记录的某个字段对应的值

    ​ 优点:能够让一个不会数据库操作的人,也能够简单快捷去使用数据库

    ​ 缺点:由于封装程度太高,可能会导致程序的执行效率偏低

    ​ 有时候结合项目需求,可能需要手写sql语句

    django的orm注意事项:

    1、django的orm不会自动帮你创建库,库需要自己手动创建;但是表会自动帮你创建,只需要书写符合django的orm语法的代码即可。

    去应用下所在的models.py中书写类来创建表

    class Userinfo(models.Model):
        # 设置id字段为userinfo表的主键  id int primary key auto_increment
        id = models.AutoField(primary_key=True)  # 在django中,可以不指定主键字段,django orm会自动创建
        # 设置username字段,相当于username varchar(64),CharField必须要指定max_length参数
        username = models.CharField(max_length=64)  # 在django orm中没有char字段,但是django暴露给用户,可以自定义char字段
        # 设置password字段,相当于password int
        password = models.IntegerField()
    

    -------------------------------------------数据库迁移(同步)命令--------------------------------------------------

    python manage.py makemigrations # 不会创建表,仅仅是生成一个记录,将你当前的操作记录到一个小本本上(migrations文件夹)

    python manage.py migrate # 将你的orm语句真正的迁移到(同步)到数据库中

    只要你在models.py中修改了跟数据库相关的代码,就必须重新执行上面两条代码

    字段的增删改查和数据的增和查

    字段的增删改查

    增:

    class Userinfo(models.Model):
        # 设置id字段为userinfo表的主键  id int primary key auto_increment
        id = models.AutoField(primary_key=True)  # 在django中,可以不指定主键字段,django orm会自动创建
        # 设置username字段,相当于username varchar(64),CharField必须要指定max_length参数
        username = models.CharField(max_length=64)  # 在django orm中没有char字段,但是django暴露给用户,可以自定义char字段
        # 设置password字段,相当于password int
        password = models.IntegerField()
        phone = models.BigIntegerField(default=110)  # 新增的字段,可以提前设置默认值
        addr = models.CharField(max_length=64, null=True)  # 新增的字段可以设置为空
    
    

    改:改了字段后一定要执行数据库迁移的两条命令

    删:注释掉要删的字段的代码,然后执行数据库迁移命令,但是这个千万不要去删

    数据的增和查

    查:

    def login(request):
        if request.method == 'POST':
            username = request.POST.get("username")
            password = request.POST.get("password")
            # 先以用户名为依据查询数据
            # 1.get()  当查询条件不存在的时候 会直接报错   如果存在会直接给你返回 数据对象本身        不推荐使用
            # res = models.Userinfo.objects.get(username=username)  # select id,username,password from userinfo where username='jason'
            # print(res)
            # print(res.username)
            # print(res.password)
            # 2.filter()   当查询条件不存在的时候  不会报错而是返回一个空
            # 当条件存在的情况下 无论数据有几条返回的都是列表套对象的数据格式
            # filter可以当多个查询条件 并且是and关系
            res = models.Userinfo.objects.filter(username=username)  # select * from userinfo where username='jason' and password=123;
            # user_obj = res[0]
            # user_obj = res[0:3]
            # user_obj = res[-1]  # 你可以将filter查询出来的结果当做列表去对待 支持正数的索引取值和切片 不支持负数
            user_obj = res.first()  # 取queryset第一个元素
            print(user_obj)
        return render(request,'login.html')
    
    

    增:

    def reg(request):
        if request.method == 'POST':
            username = request.POST.get("username")
            password = request.POST.get("password")
            # 直接将用户名和密码写入数据库
            user_obj = models.Userinfo.objects.create(username=username,password=password)
            # 相当于insert into userinfo(username,password) values('admin','666');
            # create方法会有一个返回值  返回值就是当前被创建的数据对象
            print(user_obj)
        return render(request,'register.html')
    
  • 相关阅读:
    [LeetCode 049] Group Anagrams
    [LeetCode 033] Search in Rotated Sorted Array
    [LeetCode 024] Swap Nodes in Pairs
    [LeetCode 016] 3Sum Closest
    [LeetCode 015] 3Sum
    [LeetCode 013] Roman to Integer
    [LeetCode 008] String to Integer (atoi)
    [LeetCode 007] Reverse Integer
    第四课:文件操作【解密】
    第三课:文件操作【逐步浅入,深入加解法】
  • 原文地址:https://www.cnblogs.com/zhuangyl23/p/11716993.html
Copyright © 2011-2022 走看看