Django基础知识 URL路由系统详解


Posted in Python onJuly 18, 2019

MVC和MTV框架

MVC

Web服务器开发领域里著名的MVC模式,所谓MVC就是把Web应用分为模型(M),控制器(C)和视图(V)三层,他们之间以一种插件式的、松耦合的方式连接在一起,模型负责业务对象与数据库的映射(ORM),视图负责与用户的交互(页面),控制器接受用户的输入调用模型和视图完成用户的请求,其示意图如下所示:

Django基础知识 URL路由系统详解

MTV

Django的MTV模式本质上和MVC是一样的,也是为了各组件间保持松耦合关系,只是定义上有些许不同,Django的MTV分别是值:

  • M 代表模型(Model): 负责业务对象和数据库的关系映射(ORM)。
  • T 代表模板 (Template):负责如何把页面展示给用户(html)。
  • V 代表视图(View): 负责业务逻辑,并在适当时候调用Model和Template。

除了以上三层之外,还需要一个URL分发器,它的作用是将一个个URL的页面请求分发给不同的View处理,View再调用相应的Model和Template,MTV的响应模式如下所示:

Django基础知识 URL路由系统详解

一般是用户通过浏览器向我们的服务器发起一个请求(request),这个请求回去访问视图函数,(如果不涉及到数据调用,那么这个时候视图函数返回一个模板也就是一个网页给用户),视图函数调用模型,模型去数据库查找数据,然后逐级返回,视图函数把返回的数据填充到模板中空格中,最后返回网页给用户。

Django下载安装

Django官网下载页面

1、下载Django:

pip3 install django==1.11.9

2、创建一个django project

django-admin startproject first_project #创建了一个名为"first_project"的Django 项目:

3、启动django项目

python manage.py runserver 127.0.0.1:8001
python manage.py runserver 8001 #本机就不用写ip地址了 
python manage.py runserver #如果连端口都没写,默认是本机的8000端口

这样我们的django就启动起来了,只不过什么逻辑也没有呢!

当我们访问:http://127.0.0.1:8080/时就可以看到:

Django基础知识 URL路由系统详解

Django基础知识 URL路由系统详解

当前目录下会生成first_project的工程,目录结构如下:(大家注意昂,pip下载下来的django你就理解成一个模块,而不是django项目,这个模块可以帮我们创建django项目)

Django基础知识 URL路由系统详解

  • manage.py ----- Django项目里面的工具,通过它可以调用django shell和数据库,启动关闭项目与项目交互等,不管你将框架分了几个文件,必然有一个启动文件,其实他们本身就是一个文件。
  • settings.py ---- 包含了项目的默认设置,包括数据库信息,调试标志以及其他一些工作的变量。
  • urls.py ----- 负责把URL模式映射到应用程序。
  • wsgi.py ---- runserver命令就使用wsgiref模块做简单的web server,后面会看到renserver命令,所有与socket相关的内容都在这个文件里面了,目前不需要关注它。

创建app

python manage.py startapp app名称

在settings中配置

'app01.apps.App01Config' 或者'app01'

pycharm创建django项目

1.file -->new project

Django基础知识 URL路由系统详解

2.Django -->项目名称 -->选择Python选择器 -->应用名称(业务逻辑相关的程序)

Django基础知识 URL路由系统详解

项目目录结构:

Django基础知识 URL路由系统详解

写一个Django项目:

做一个登录页面的Web项目,浏览器输入网址得到一个web页面
输入网址:127.0.0.1:8000/login/

1.创建项目 second_pro

2.创建app app02

3.urls.py

from django.conf.urls import url
  from django.contrib import admin
  from app02 import views

  urlpatterns = [
    # url(r'^admin/', admin.site.urls),
    url(r'^index/', views.index),

  ]

4.views.py 写逻辑视图

from django.shortcuts import render,HttpResponse
  # Create your views here.
  def index(request):
    # print(request.method)  #获取请求方式GET或POST
    if request.method=='GET':
      return render(request,'login.html') #回复一个页面
    else:
      username=request.POST.get('username')  #获取post数据
      password=request.POST.get('password')
      if username=='anwen' and password=='123':
        return HttpResponse('登录成功!')  #回复字符串
      else:
        return HttpResponse('登录失败!')

5.在templates文件夹中创建login.html 页面

<!DOCTYPE html>
  <html lang="en">
  <head>
    <meta charset="UTF-8">
    <title>login</title>
  </head>
  <body>
  <form action="/index/" method="post">
    <div>
      用户名:<input type="text" name="username">
    </div>
    <div>
      密码: <input type="text" name="password">
    </div>
    <input type="submit">
  </form>
  </body>
</html>

注意:

1.urls.py 里面需要注意的问题:

url(r'index/',views.index) #第一个参数路径正则字符串,第二个参数对应的视图逻辑

2.

def index(request):
    # print(request.method)  #获取请求方式GET或POST
    request.GET ---GET请求发送来的所有数据,queryDict类型
    request.POST ---POST请求发送来的所有数据,queryDict类型
    request.GET.get('username')   #获取get数据
    request.POST.get('username')  #获取post数据
    
    return render(request,'login.html') #回复一个页面
    return HttpResponse('登录成功!')  #回复字符串

get请求获取数据:

def index(request):
 print(retuest.GET) #<QueryDict:{'username':'anwen','password':['123']}>
 username=request.GET.get('username')
 password=request.GET.get('password')
 print(username,password)
 
 if username=='anwen' and password =='123':
  return HttpResponse('登录成功')
 else:
  return HttpResponse('登录失败')

post请求提交数据时关掉一个认证机制,settings配置文件中

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',
]

URL配置

无名分组

url(r'^books/(\d{4})/',views.books)  #(\d{4})

位置参数

url(r'^books/(\d{4})/',views.year_books) #匹配年份
url(r'^books/(\d{4})/(\d{1,2})/',views_year_month_books) #匹配年份和月份
#http://127.0.0.1:8000/books/2019/2/

视图:

def year_month_books(request,year,month): #位置参数 ,第一个参数接收的是无名分组路径中匹配到的第一个的分组数据,第二个参数接收到的就是无名分组中路径中匹配到的第二个分组数据
 print(year,month)

分组命名匹配

在Python的正则表达式中,分组命名正则表达式组的语法是(?P<name>pattern),其中name是组的名称,pattern是要匹配的模式。使用命名组的重写

url(r'^books/(?p<year>\d{4})/(?p<month>\d{1,2}/',views.year_month_books)#匹配年份和月份
def year_month)books(request,.month,year):#形参名称要和url中的分组名称对应,参数位置没有顺序要求
 print(year,month)

默认值

#urls.py中
from django.conf.url import url
from . import views
urlpatterns=[
 # 视图函数中指定默认值,如果第一个模式匹配上了,year_books()函数将使用其默认参数num=“1”,如果第二个模式匹配,year_books()将使用正则表达式捕获到的num值。
 url(r'^books/$', views.year_books),
 url(r'^books/(?P<num>\d{4})', views.year_books),
]

#views.py中
def pag(request,num='10'):
 pass

注意事项

  • urlpatterns中的元素按照书写顺序从上往下逐一匹配正则表达式,一旦匹配成功则不再继续。
  • 若要从URL中捕获一个值,只需要在它周围放置一对圆括号(分组匹配)。
  • 不需要添加一个前导的反斜杠(也就是写在正则最前面的那个/),因为每个URL 都有。例如,应该是^articles 而不是 ^/articles。
  • 每个正则表达式前面的'r' 是可选的但是建议加上。
  • ^articles& 以什么结尾,以什么开头,严格限制路径

url末尾加'/'补充说明

#是否开启URL访问地址后面不为/跳转至带有/的路径的配置项
APPEND_SLASH=True

Django settings.py配置文件中默认没有 APPEND_SLASH 这个参数,但 Django 默认这个参数为 APPEND_SLASH = True。 其作用就是自动在网址结尾加'/'。其效果就是:我们定义了urls.py:
 from django.conf.urls import url
 from app01 import views

 urlpatterns = [
   url(r'^blog/$', views.blog),
 ]
 
访问 http://www.example.com/blog 时,默认将网址自动转换为 http://www.example/com/blog/ 。

如果在settings.py中设置了 APPEND_SLASH=False,此时我们再请求 http://www.example.com/blog 时就会提示找不到页面。

url路由分发之include

#项目文件夹下的urls.py文件中的url写法:
 from django.conf.urls import url,include
 from django.contrib import admin
 from app01 import views
 urlpatterns = [
  # url(r'^admin/', admin.site.urls),
  #首页
  url(r'^$', views.base),

  url(r'^app01/', include('app01.urls')),

  url(r'^app02/', include('app02.urls')),

 ]
 
#app01下urls.py内容写法
 from django.conf.urls import url
 from django.contrib import admin
 from app01 import views
 urlpatterns = [
  # url(r'^admin/', admin.site.urls),
  url(r'^$', views.app01base),
  url(r'^index/', views.index),
 ]
 
#app02下urls.py内容写法 
 from django.conf.urls import url
 from django.contrib import admin
 from app02 import views

 urlpatterns = [
  # url(r'^admin/', admin.site.urls),
  url(r'^$', views.app02base),
  url(r'^home/', views.home),

 ]

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Python 相关文章推荐
Python 出现错误TypeError: ‘NoneType’ object is not iterable解决办法
Jan 12 Python
Python实现树莓派WiFi断线自动重连的实例代码
Mar 16 Python
python 限制函数执行时间,自己实现timeout的实例
Jan 12 Python
介绍一款python类型检查工具pyright(推荐)
Jul 03 Python
利用pyecharts实现地图可视化的例子
Aug 12 Python
python2.7的flask框架之引用js&amp;css等静态文件的实现方法
Aug 22 Python
使用python实现离散时间傅里叶变换的方法
Sep 02 Python
在vscode中配置python环境过程解析
Sep 28 Python
Django自带的加密算法及加密模块详解
Dec 03 Python
python opencv实现gif图片分解的示例代码
Dec 13 Python
通过实例了解Python异常处理机制底层实现
Jul 23 Python
总结Python变量的相关知识
Jun 28 Python
对Django项目中的ORM映射与模糊查询的使用详解
Jul 18 #Python
Django基础知识 web框架的本质详解
Jul 18 #Python
django 使用全局搜索功能的实例详解
Jul 18 #Python
Django中Middleware中的函数详解
Jul 18 #Python
对DJango视图(views)和模版(templates)的使用详解
Jul 17 #Python
react+django清除浏览器缓存的几种方法小结
Jul 17 #Python
在Pycharm中调试Django项目程序的操作方法
Jul 17 #Python
You might like
php实现memcache缓存示例讲解
2013/12/04 PHP
PHP函数strip_tags的一个bug浅析
2014/05/22 PHP
php生成RSS订阅的方法
2015/02/13 PHP
PHP请求远程地址设置超时时间的解决方法
2016/10/29 PHP
extjs 学习笔记(二) Ext.Element类
2009/10/13 Javascript
javascript实现tabs选项卡切换效果(自写原生js)
2013/03/19 Javascript
js+html5绘制图片到canvas的方法
2015/06/05 Javascript
JS基于Ajax实现的网页Loading效果代码
2015/10/27 Javascript
基于jQuery实现简单的折叠菜单效果
2015/11/23 Javascript
js实现网页图片延时加载 提升网页打开速度
2016/01/26 Javascript
JS如何设置cookie有效期为当天24点并弹出欢迎登陆界面
2016/08/04 Javascript
简单几步实现返回顶部效果
2016/12/05 Javascript
微信小程序 九宫格实例代码
2017/01/21 Javascript
详解微信小程序 wx.uploadFile 的编码坑
2017/01/23 Javascript
JS实现遍历不规则多维数组的方法
2018/03/21 Javascript
微信小程序实现上传图片功能
2018/05/28 Javascript
从零开始用electron手撸一个截屏工具的示例代码
2018/10/10 Javascript
[14:00]DOTA2国际邀请赛史上最长大战 赛后专访B神
2013/08/10 DOTA
[02:15]2015国际邀请赛选手档案IG.Ferrari 430
2015/07/30 DOTA
[01:15:56]2018DOTA2亚洲邀请赛3月30日 小组赛A组 TNC VS Newbee
2018/03/31 DOTA
Python实现去除代码前行号的方法
2015/03/10 Python
详解Python中的多线程编程
2015/04/09 Python
Python中应该使用%还是format来格式化字符串
2018/09/25 Python
wxpython多线程防假死与线程间传递消息实例详解
2019/12/13 Python
python模拟哔哩哔哩滑块登入验证的实现
2020/04/24 Python
python中元组的用法整理
2020/06/15 Python
python和JavaScript哪个容易上手
2020/06/23 Python
python dict如何定义
2020/09/02 Python
美国宠物护理专家:Revival Animal Health
2020/01/05 全球购物
东方红海科技面试题软件测试方面
2012/02/08 面试题
机修工岗位职责
2013/11/24 职场文书
毕业生的自我鉴定该怎么写
2013/12/02 职场文书
读书小明星事迹材料
2014/05/03 职场文书
学习型班组申报材料
2014/05/31 职场文书
律师催款函范文
2015/06/24 职场文书
php去除数组中为0的元素的实例分析
2021/11/17 PHP