ToB企服应用市场:ToB评测及商务社交产业平台
标题:
Django-静态文件配置,链接数据库,request对象方法
[打印本页]
作者:
锦通
时间:
2022-10-22 23:10
标题:
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>
{# #}
{# 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' %}">
</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">
</head>
<body>
<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>
</body>
</html>
复制代码
html03_login example.htmlurl
path('loginStudy/', views.loginStudy),
复制代码
免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!
欢迎光临 ToB企服应用市场:ToB评测及商务社交产业平台 (https://dis.qidao123.com/)
Powered by Discuz! X3.4