Django主要目录结构
# 以创建mysite项目为例
mysite文件夹
mysite同名文件夹
settings.py
# django暴露给用户可以自定义配置的文件
urls.py
# 存放路由(路径)与函数(视图函数)对应关系
wsgi.py
# 依赖于wsgiref模块的socket启动部分
manage.py文件
# django的入口(启动)文件
app01文件夹
migrations文件夹
# 里面存放ORM针对数据库相关的记录,相当于日志
admin.py
# django自带的后台管理功能
apps.py
# 每个应用的独立标识
models.py
# 与数据库打交道的文件(ORM)
tests.py
# 自带的测试文件
views.py
# 该app对应的主体功能(函数 类)
db.sqlite3
# django自带的小型数据库(针对日期格式无法精准存取)
"""
1.创建app之后一定要去settings.py中注册
INSTALLED_APPS = [
# 全写
\'app01.apps.App01Config\',
# 简写
\'app02\'
]
2.templates路径配置
TEMPLATES = [
{
\'DIRS\': [os.path.join(BASE_DIR, \'templates\')]
}
"""
django是可以自动重启的 但是有时候自动重启的反应时间有点长
django小白必会三板斧
1.HttpResponse
HttpResponse(\'hello django!\')
暂且理解为可以返回给前端浏览器文本类的数据
2.render
render(request,\'index.html\',{\'n1\':[1,2,3]}) # 精准传(复杂但节省资源)
render(request,\'index.html\',locals()) # 范围传(简单但不节省资源)
返回给前端浏览器html页面 并且提供模板语法(不需要借助jinja2模块)
# 注:定义函数时记得加个request形参
html文件接收其他参数 {{\'n1\'}}
支持在html模板语法:遍历直接写个for按table键自动补全
3.redirect
重定向
redirect(\'https://www.baidu.com\') # 可以写全称
redirect(\'/admin/\') # 也可以只写后缀(默认补齐当前IP和PORT)
urls.py 存放路由与视图函数对应关系 路由层
views.py 存放视图函数(核心业务逻辑) 视图层
templates文件夹 存放html文件 模板层
models.py 存放与数据库相关的代码(ORM) 模型层
"""
1.django默认的端口号是8000
在同一台机器同一时间如果需要运行多个django项目 需要修改端口号
python3 manage.py runserver ip:port
pycharm自主修改
2.浏览器缓存(django修改之后没有效果)
修改谷歌浏览器设置,打开检查界面会自动清除缓存
打开检查界面
settings
networks
disable cache(勾选)
"""
静态文件配置
# 利用django编写用户登录功能
# 什么是静态文件
不会频繁更改的文件
css文件、js文件、第三方框架文件、图片
# django存储静态文件
我们需要新建一个static文件夹用来存放静态文件
static文件夹
该文件内部还可以依据不同的功能划分不同的区域
css文件夹
js文件夹
img文件夹
others文件夹
\'\'\'为什么前端请求不到后端的框架资源:我们没有开设对应的资源接口\'\'\'
# 如何开放接口
一般接口我们需要在urls.py文件中建立对应关系,针对静态资源的路径开设无需在urls.py中指定 只需要在配置文件(setting.py)指定即可
找到这一行:STATIC_URL = \'/static/\',在底下添加
STATICFILES_DIRS = [
os.path.join(BASE_DIR,\'static\')
]
/static/bootstrap-3.4.1-dist/js/bootstrap.min.js
这样只要我们的路径输入正确就可以访问static文件夹下的内容
# 注:两个static表示的作用并不相同
# 进阶关系
STATIC_URL = \'/static/\' # 接口前缀(要想访问静态资源 那么路径的前缀就必须是这里指定的/static/) 接口前缀可以修改,但我们一般不会修改
# 进行路径的拼接,将static文件夹添加到配置文件(可以将static文件夹下所有的资源开设给外界)
STATICFILES_DIRS = [
os.path.join(BASE_DIR,\'static\'), # 文件夹名称
os.path.join(BASE_DIR,\'static1\'), # 文件夹名称
os.path.join(BASE_DIR,\'static2\') # 文件夹名称
]
"""
接口前缀正确之后 拿着后面的路径去列表中
从上往下依查找对应的资源 找到了就不再继续往下找
"""
# 接口前缀动态匹配
# 固定搭配,记住即可,在html文件导入静态文件的时候
{% 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>
网络请求方式
1.get请求
向别人索要数据
eg:浏览器地址栏输入www.baidu.com回车
get请求没有请求体
get请求也可以携带一些的额外的参数 但是大小有限制(2KB)
url?xxx=yyy&aaa=bbb
2.post请求
向别人提交数据
eg:用户注册登录填写完身份数据之后提交
post请求有请求体
post请求也可以携带数据 并且大小没有限制 在请求体中
form表单重要参数
<form action="" method="post">
</form>
action # 控制数据提交的地址
1.写全路径 https://www.baidu.com
2.写后缀(ip和端口自动补全当前服务器) /index/
3.不写 提交给当前页面所在的地址
method # 控制数据提交的方式
get form表单默认是get请求
post
"""
注意使用django前期在提交post请求之前需要去配置文件中注释掉一行代码
MIDDLEWARE = [
# \'django.middleware.csrf.CsrfViewMiddleware\',
]
"""
requests对象方法
request.method # 获取请求方式名(纯大写的字符串)
request.POST # 获取post请求提交的普通数据(文件无法获取)
request.POST.get() # 默认只会取列表最后一个元素
request.POST.getlist() # 获取所有元素
request.GET # 获取get请求url问号后面的数据
request.GET.get()
request.GET.getlist()
def login(request):
if request.method == \'POST\':
username = request.POST.get(\'username\') # 默认只会取列表最后一个元素
password = request.POST.get(\'password\')
if username == \'jason\' and password == \'123\':
return HttpResponse(\'OK\')
else:
return HttpResponse(\'用户名或密码错误\')
return render(request, \'login.html\')
pycharm链接MySQL
需要借助pymysql模块
django链接MySQL
# 第一步配置
DATABASES = {
\'default\': {
\'ENGINE\': \'django.db.backends.mysql\',
\'NAME\': \'db4_3\',
\'USER\':\'root\',
\'PORT\':3306,
\'HOST\':\'127.0.0.1\',
\'PASSWORD\':\'123\',
\'CHARSET\':\'utf8\'
}
}
# 第二步配置(3.6及以下解释器 需要额外的配置)
import pymysql
pymysql.install_as_MySQLdb()
\'\'\'只要是__init__文件即可 项目的 应用的都可以\'\'\'
简易登录页面
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
<script src="https://cdn.bootcdn.net/ajax/libs/jquery/3.4.1/jquery.min.js"></script>
{% 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>
<div class="container">
<div class="row">
<h1 class="text-center">登录界面</h1>
<div class="clo-md-8 col-md-offset-2">
<form action="" method="post">
<p>username:
<input type="text" class="form-control" name="username">
</p>
<p>password:
<input type="password" class="form-control" name="password">
</p>
<input type="submit" class = "btn btn-success btn-block" value="登录">
</form>
</div>
</div>
</div>
</body>
</html>
总结
1.利用pycharm创建一个django项目和app
python3 manage.py startapp app01(命令行创建)
# 注:新创建的app需要添加到配置文件(insert)
也可以在创建django项目是自动创建一个app(一个app相当于一个功能)
2.新增一个login方法
在url.py和views.py文件添加对应关系
"定义函数时要记得添加形参request"
小白必会三板斧
return Httpresponse() # 返回字符
return render(request,\'html文件\') # 返回html界面
可以在后面以字典形式添加其他参数(无需借助jinja2模块)
html文件采用{{}}形式接收,同时支持模块语法
return redirect() # 重定向,可以转到其他界面
return redirect(\'http://www.baidu.com\') 完整格式
return redirect(\'/admin\') 会自动将本界面ip+port拼接
3.编写html文件
class=\'containter\'
class=\'row\'
h1:text-center
class=\'col-md-8 col-md-offset-2\'
form表单
参数:
input标签 class=\'form-contol\' # 与用户交互
submit标签 btn btn-success btn-block
4.静态文件
新增一个文件夹存放静态文件static
可以按功能分为css文件、js文件等等
# 解决无法识别导入html文件的css、js文件,原因是我们只能访问在url有对应关系的
对ststic文件夹开放接口
打开setting配置文件,找到STSTIC = \'/static/\'
在底下添加
STATICFILE_DIRS = [
os.path.join(BASIC_DIR,\'static\')
]
# 我们将ststic文件夹底下的文件添加到配置,只要是以/static/开头且在ststic文件夹下的路径都能够访问
# 接口前缀动态匹配
固定搭配
{% load ststic %}
{% static \'\' %}
在html文件在导入静态文件时使用
{% 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>
5.form表单重要参数
<form action="" method="post">
</form>
action # 控制数据提交的地址
1.写全路径 https://www.baidu.com
2.写后缀(ip和端口自动补全当前服务器) /index/
3.不写 提交给当前页面所在的地址
method # 控制数据提交的方式
get form表单默认是get请求
post
6.获取提交方式
request.method # 根据提交方式返回不同的界面