Django-静态文件配置,链接数据库,request对象方法

目录

-静态文件配置

--含义

--配置方法

--动态解析

---含义

---实现

---示例

-pycharm链接MySQL

-Django链接MySQL

--代码配置

--代码声明

-request对象常用方法

--示例


-静态文件配置

--含义

静态文件指一些写好的固定文件,直接使用即可

eg:
    网站写好的js文件
    网站写好的css文件
    网站用到的image文件
    第三方功能包
    ......

一般我们都将静态文件放在项目的static目录下,并对不同静态文件划分处理

--static
    ---js
    ---css
    ---image

--配置方法

STATIC_URL = '/static/'
"""
配置静态文件目录名为static,自动在项目文件下创建
类似于开门的钥匙,后续访问需要带上钥匙才能进入,如/static/js/bootstrap.min.js
"""
STATICFILES_DIRS = [
    os.path.join(BASE_DIR, 'static'),
    os.path.join(BASE_DIR, 'static2'),  # 可以放多个
]
"""
静态文件路径拼加,可以放多个,从上往下找,先找到的先使用
"""

--动态解析

---含义

STATIC_URL一配置,后续使用都需加上该"钥匙"
但倘若STATIC_URL设置的名称一改,那后续使用了静态文件的路径都要改
假想一个图片网站使用了上万张静态文件中的图片,那岂不是这万个路径都得改?
因此比较麻烦,引入动态解析的使用

---实现

引用时使用如下方式:
    {% load static %}   # 先加载出static,必写
 
    使用时="{% static '文件在static中的路径' %}"
 
这样不管STATIC_URL改为什么,前端引用时自动匹配该名称拼加路径使用

---示例

 html02_jintaiwenjianpeizhi.html

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>静态文件配置示例</title>
    {# <script src="/static/bootstrap-3.4.1-dist/js/bootstrap.min.js"></script> #}
    {# link rel="stylesheet" href="/static/bootstrap-3.4.1-dist/css/bootstrap.min.css"> #}
    {% load static %}
    <link rel="stylesheet" href="{% static 'bootstrap-3.4.1-dist/css/bootstrap.min.css' %}">
    <script src="{% static 'bootstrap-3.4.1-dist/js/bootstrap.min.js' %}"></script>
</head>
<body>
    <h1 class="text-center">login successfully</h1>
</body>
</html>

-pycharm链接MySQL

找到链接数据库的位置

 一定要先下载驱动,再输入密码等测试连接

 test connecttion出现对钩了才确定,不然换mysql重新下驱动

 

 

 就可pycharm操作数据库了  但操作完后一定要点提交

 

-Django链接MySQL

Django配置文件中有如下代码,默认用的sqlite3
DATABASES = {
    'default': {
        'ENGINE': 'django.db.backends.sqlite3',
        'NAME': os.path.join(BASE_DIR, 'db.sqlite3'),
    }
}

--代码配置

将原来的注释掉,改为以下
 
DATABASES = {
    'default':{
        'ENGINE': 'django.db.backends.mysql',
        'NAME': '自己的数据库',
        'USER': '自己的用户',
        'PASSWORD': '自己设置的密码',
        'HOST': '127.0.0.1',
        'PORT': 3306,
        'CHARSET': 'utf8' # !!!注意不加-  
    }
}

--代码声明

django默认使用mysqldb链接MySQL
但该模块兼容性不太好,需要手动改为pymysql链接
要想Django项目真正运行起来,还需去项目名文件夹或任意应用文件夹下的__init__.py中配置两句话(即下面的代码声明)
 
# 代码声明
import pymysql
pymysql.install_as_MySQLdb()

-request对象常用方法

request.method    # 返回用户数据请求格式:POST GET 大写字符串格式
 
request.POST      # 得到用户提交的数据(不含文件)  字典
    request.POST.get('key')      # 拿到对应key下的值 为列表最后一个元素
    request.POST.getlist('key')  # 拿到对应key下的所有值 即一个列表
 
request.GET       # 得到用户提交的数据(不含文件)  字典
    request.GET.get('key')       # 拿到对应key下的值 为列表最后一个元素
    request.GET.getlist('key')   # 拿到对应key下的所有值 即一个列表
 
# PS:GET请求拿到的数据大小有限制 4KB左右吧 而post请求无限制 

--示例

views.py

def loginStudy(request):
    # 一般不用这种两个if的方法,而用一个if省一行缩近,但用也可以
    # if request.method == 'POST':
    #     pass
    # elif request.method == 'GET':
    #     pass
    if request.method == 'POST':    # 返回的是字符串大写格式,如'POST','GET'
        # print(request.POST)
        # request.POST返回的是一个字典 <QueryDict: {'username': ['weer'], 'password': ['123']}>
        username = request.POST.get('username') # 即可以用字典的方法取值 weer
        hobby = request.POST.get('hobby')
        # 只返回hobby下列表的最后一个值即'333'
        hobby_list1 = request.POST.getlist('hobby')
        # 得到hobby下的整个列表 ['111', '222', '333']
        print(username, hobby_list1)
        return render(request, 'html02_jintaiwenjianpeizhi.html')
    # GET请求方式提交的,也能获取数据,get(),getlist()得到数据同POST方式
    # 比如地址栏中:http://127.0.0.1:8000/loginStudy/?password=123&hobby=[111,222,333]
    password = request.GET.get('password')  # 123
    hobby_list2 = request.GET.getlist('hobby') # ['111', '222', '333']
    print(password, hobby_list2)
    return render(request, 'html03_login example.html')
views.py

 html03_login example.html

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>登录界面 后台数据获取</title>
    <link rel="stylesheet" href="/static/bootstrap-3.4.1-dist/css/bootstrap.min.css">
    <script src="/static/bootstrap-3.4.1-dist/js/bootstrap.min.js"></script>
</head>
<body>
    <div class="container">
        <div class="col-md-8 col-md-offset-2">
            <form action="/loginStudy/" method="post">
                <h2 class="text-center">登录</h2>
                <p>username:<input type="text" name="username" class="form-control"></p>
                <p>password<input type="password" name="password" class="form-control"></p>
                <p>
                    <input type="checkbox" name="hobby" value="111">111
                    <input type="checkbox" name="hobby" value="222">222
                    <input type="checkbox" name="hobby" value="333">333
                </p>
                <p><input type="submit" class="btn btn-success btn-block"></p>
            </form>
        </div>
    </div>
</body>
</html>
html03_login example.html

url

path('loginStudy/', views.loginStudy),
posted @ 2022-10-22 23:16  weer-wmq  阅读(33)  评论(0编辑  收藏  举报