django--MTV基础模型
今天就进入到python最重要的阶段了django框架,框架就像胶水一样会将我们前面学的所有知识点粘合在一起,所以以前有哪些部分模糊的可以看看前面的随笔。本篇主要介绍djangoMTV模型,视图层之路由配置系统(URlconf)和视图层之视图函数(views)。
本篇导航:
1、python主要框架:
django:大而全
flask:小而精
2、Django的MTV
Model(模型):数据库相关的操作(ORM)
Template(模版):模板语法--->将变量(数据库数据)如何巧妙嵌入html页面中
View(视图):逻辑处理
此外,Django还有一个urls分发器:路径与视图函数的映射关系
3、关系图
1、下载
pip3 install django
2、创建项目
django-admin.py startproject mysite
manage.py ----- Django项目里面的工具,通过它可以调用django shell和数据库等。
settings.py ---- 包含了项目的默认设置,包括数据库信息,调试标志以及其他一些工作的变量。
urls.py ----- 负责把URL模式映射到应用程序。
3、创建应用
python manage.py startapp blog
models.py --- 数据库相关的操作。
tests.py --- 用于测试
views.py --- 用来写逻辑处理
4、启动项目
python manage.py runserver IP PORT
IP:可以不写 不写默认本机
PORT(端口):可以不写 不写默认8000
功能:建立起url与视图函数的映射关系。
也就是告诉Django,对于这个URL调用这段代码,对于那个URL调用那段代码。
基本格式:
'''
urlpatterns = [
url(正则表达式, views视图函数,参数,别名),
]
参数说明:
一个正则表达式字符串
一个可调用对象,通常为一个视图函数或一个指定视图函数路径的字符串
可选的要传递给视图函数的默认参数(字典形式)
一个可选的name参数
'''
1、简单举例
from django.conf.urls import url
from 项目 import views
urlpatterns = [
url(r'^articles/2003/$', views.special_case_2003),
url(r'^articles/([0-9]{4})/([0-9]{2})/$', views.month_archive),
]
注意:
'''
一旦匹配成功则不再继续 只匹配第一个url
若要从URL 中捕获一个值,只需要在它周围放置一对圆括号。
不需要添加一个前导的反斜杠,因为每个URL 都有。例如,应该是^articles 而不是 ^/articles。
每个正则表达式前面的'r' 是可选的但是建议加上。
'''
2、有名分组
1 无名分组
url(r'^articles/(\d{4})/(\d{2})$', views.year_month)
# year(requset,1990,12)
按位置传参数
2 有名分组
url(r'^articles/(?P<year>\d{4})/(?P<month>\d{2})$', views.year_month)
# year(requset,year=1990,month=12) 按位置传参数
3、查找方式
在http://www.example.com/myapp/ 请求中,URLconf 将查找myapp/ 。
在http://www.example.com/myapp/?page=3 请求中,URLconf 仍将查找myapp/。
URLconf 不检查请求的方法。所有的请求方法--> 同一个URL的POST、GET、HEAD等等--> 都将路由到相同的函数。
4、url 分发
如果一个项目中应用太多,导致方法太多耦合性太强,所以我们可以用include进行解耦,在每一个应用中分别建立一个urls
项目中的urls:
from django.conf.urls import include, url
from django.contrib import admin
urlpatterns = [
url(r'^admin/', admin.site.urls),
url(r'^blog/', include('blog.urls')),
]
应用中的urls:
from django.conf.urls import url
import views
urlpatterns = [
url(r'^articles/2003/05$', views.year_month2), # year(requset,1990,12)
url(r'^articles/(?P<year>\d{4})/(?P<month>\d{2})$', views.year_month), # year(requset,year=1990,month=12) 按位置传参数
]
5、传递额外的选项给视图函数(了解)
django.conf.urls.url()
函数可以接收一个可选的第三个参数,它是一个字典,表示想要传递给视图函数的额外关键字参数。
from django.conf.urls import url
from . import views
urlpatterns = [
url(r'^blog/(?P<year>[0-9]{4})/$', views.year_archive, {'foo': 'bar'}),
]
在这个例子中,对于/blog/2005/
请求,Django 将调用views.year_archive(request, year='2005', foo='bar')
。
6、URL 的反向解析(别名)
例如:以下URL(name)
from django.conf.urls import url
from django.contrib import admin
from app1 import views
urlpatterns = [
url(r'^admin/', admin.site.urls),
url(r'^$', views.login),
url(r'^login/', views.login,name="login")
]
你可以在模板的代码中使用下面的方法获得它们(提交:action):(模板后面会说到)
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
</head>
<body>
<h1>登录页面</h1>
<form action="{% url "login" %}" method="post">
<p><input type="text" name="user"></p>
<p><input type="password" name="pwd"></p>
<p><input type="submit"></p>
</form>
</body>
</html>
这样当你的匹配规则及路径发生变动时其他地方不会发生错误
1、简单视图:
一个视图函数,简称视图,用来逻辑处理。是一个简单的Python 函数,它接受Web请求并且返回Web响应。
1)下面是一个返回当前日期和时间作为HTML文档的视图:
from django.http import HttpResponse
import datetime
def current_datetime(request):
now = datetime.datetime.now()
html = "<html><body>It is now %s.</body></html>" % now
return HttpResponse(html)
2)一定包含两个对象:
requset---->请求信息
Httpresponse---->响应字符串
2、request里包含哪些数据(重点)
request.GET: GET请求的数据 {}
request.POST:POST请求的数据 {}
request.method:请求方式:GET 或 POST
请求某个键下多个值时:
request.POST.getlist("hobby")
request.path : 请求路径
请求url:http://127.0.0.1:8000/index.html/23?a=1
request.path:/index.html/23
request.get_full_path()
请求url:http://127.0.0.1:8000/index.html/23?a=1
request.get_full_path():/index.html/23?a=1
COOKIES:
包含所有cookies的标准Python字典对象;keys和values都是字符串。
FILES:
包含所有上传文件的类字典对象;FILES中的每一个Key都是<input type="file" name="" />标签中name属性的值,FILES中的每一个value同时也是一个标准的python字典对象,包含下面
三个Keys:filename:上传文件名,用字符串表示,content_type: 上传文件的Content Type, content:上传文件的原始内容
user:
是一个django.contrib.auth.models.User对象,代表当前登陆的用户。如果访问用户当前没有登陆,user将被初始化为django.contrib.auth.models.AnonymousUser的实例。你可以
通过user的is_authenticated()方法来辨别用户是否登陆:if req.user.is_authenticated();只有激活Django中的AuthenticationMiddleware时该属性才可用
session:
唯一可读写的属性,代表当前会话的字典对象;自己有激活Django中的session支持时该属性才可用。
3、Httpresponse函数
HttpReponse是服务器接收到浏览器的请求后,处理返回结果常用的一个类。主要用于返回字符串。
它是在每次请求中必有的,哪怕你用的是render例如:
def render(request, template_name, context=None, content_type=None, status=None, using=None):
"""
Returns a HttpResponse whose content is filled with the result of calling
django.template.loader.render_to_string() with the passed arguments.
"""
content = loader.render_to_string(template_name, context, request, using=using)
return HttpResponse(content, content_type, status)
render内部函数最终还是返回了HttpResponse
4、render函数
render(request, template_name[, context])
结合一个给定的模板和一个给定的上下文字典,并返回一个渲染后的 HttpResponse 对象。
参数:
request: 用于生成响应的请求对象。
template_name:要使用的模板的完整名称,可选的参数(也就是我们说的网页)
context:添加到模板上下文的一个字典。默认是一个空字典。如果字典中的某个值是可调用的,视图将在渲染模板之前调用它。
content_type:生成的文档要使用的MIME类型。默认为DEFAULT_CONTENT_TYPE 设置的值。
status:响应的状态码。默认为200。
def index(request):
name="yuan"
return render(request,"index.html",{"n":name})
5、redirect 函数(重定向)
参数可以是:
一个模型:将调用模型的get_absolute_url() 函数
一个视图,可以带有参数:将使用urlresolvers.reverse 来反向解析名称
一个绝对的或相对的URL,将原封不动的作为重定向的位置。
默认返回一个临时的重定向;传递permanent=True 可以返回一个永久的重定向。
def index(request):
return redirect("/login.html/")
会从urls中重新走一遍login.html的视图函数 也可以直接写地址进行重定向
6、render和resdirect的区别
render: 只是返回页面内容,但是未发送第二次请求,url未刷新,所以当刷新后又会回到前页面。
redirect:发送了第二次请求,url更新
if 页面需要模板语言渲染,需要的将数据库的数据加载到html,那么render方法则不会显示这一部分。
注意:
使用post请求时需要在settings.py配置文件中注释一行代码
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',
]