Python Django基础二之URL路由系统


Posted in Python onJuly 18, 2019

MVC和MTV框架

MVC

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

Python Django基础二之URL路由系统

| M:models数据库相关;V:views视图相关 C:controller控制器 url分发 |

MTV

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

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

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

Python Django基础二之URL路由系统

| M:models数据库相关; T:templates模板 html文件 ;V:views视图相关 + 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/时就可以看到:

Python Django基础二之URL路由系统

Python Django基础二之URL路由系统

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

Python 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

Python Django基础二之URL路由系统

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

Python Django基础二之URL路由系统

项目目录结构:

Python 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

注意事项

  1. urlpatterns中的元素按照书写顺序从上往下逐一匹配正则表达式,一旦匹配成功则不再继续。
  2. 若要从URL中捕获一个值,只需要在它周围放置一对圆括号(分组匹配)。
  3. 不需要添加一个前导的反斜杠(也就是写在正则最前面的那个/),因为每个URL 都有。例如,应该是^articles 而不是 ^/articles。
  4. 每个正则表达式前面的'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 Django基础二之URL路由系统 ,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!
如果你觉得本文对你有帮助,欢迎转载,烦请注明出处,谢谢!

Python 相关文章推荐
从零学python系列之浅谈pickle模块封装和拆封数据对象的方法
May 23 Python
Python中基础的socket编程实战攻略
Jun 01 Python
Python 中 function(#) (X)格式 和 (#)在Python3.*中的注意事项
Nov 30 Python
python最小生成树kruskal与prim算法详解
Jan 17 Python
Python+OpenCV采集本地摄像头的视频
Apr 25 Python
Python pandas.DataFrame 找出有空值的行
Sep 09 Python
django admin后管定制-显示字段的实例
Mar 11 Python
基于Python爬取京东双十一商品价格曲线
Oct 23 Python
对pytorch中x = x.view(x.size(0), -1) 的理解说明
Mar 03 Python
python3实现无权最短路径的方法
May 12 Python
基于Python实现对比Exce的工具
Apr 07 Python
Python测试框架pytest高阶用法全面详解
Jun 01 Python
使用django的objects.filter()方法匹配多个关键字的方法
Jul 18 #Python
Django基础三之视图函数的使用方法
Jul 18 #Python
详解python实现小波变换的一个简单例子
Jul 18 #Python
Django基础知识 URL路由系统详解
Jul 18 #Python
对Django项目中的ORM映射与模糊查询的使用详解
Jul 18 #Python
Django基础知识 web框架的本质详解
Jul 18 #Python
django 使用全局搜索功能的实例详解
Jul 18 #Python
You might like
网站加速 PHP 缓冲的免费实现方法
2006/10/09 PHP
PHP中echo和print的区别
2014/08/28 PHP
php获取从百度、谷歌等搜索引擎进入网站关键词的方法
2015/07/08 PHP
php创建无限级树型菜单
2015/11/05 PHP
基于JQuery的Pager分页器实现代码
2010/07/17 Javascript
File, FileReader 和 Ajax 文件上传实例分析(php)
2011/04/27 Javascript
jQuery 1.7.2中getAll方法的疑惑分析
2012/05/23 Javascript
javascript 兼容所有浏览器的DOM扩展功能
2012/08/01 Javascript
根据json字符串生成Html的一种方式
2013/01/09 Javascript
常见的jQuery选择器汇总
2014/11/24 Javascript
Bootstrap开发实战之响应式轮播图
2016/06/02 Javascript
javascript self对象使用详解
2016/10/18 Javascript
JS实现的简易拖放效果示例
2016/12/29 Javascript
微信小程序 swiper制作tab切换实现附源码
2017/01/21 Javascript
ES6学习之变量的两种命名方法示例
2017/07/18 Javascript
jquery实现图片无缝滚动 蒙版遮蔽效果
2020/01/11 jQuery
微信小程序聊天功能的示例代码
2020/01/13 Javascript
node.js使用 http-proxy 创建代理服务器操作示例
2020/02/10 Javascript
vue中组件通信详解(父子组件, 爷孙组件, 兄弟组件)
2020/07/27 Javascript
原生JavaScript实现留言板
2021/01/10 Javascript
[00:12]2018DOTA2亚洲邀请赛 Sccc亮相SOLO赛,今年他又会有什么样的战绩?
2018/04/06 DOTA
详解python运行三种方式
2019/05/13 Python
python打造爬虫代理池过程解析
2019/08/15 Python
使用python将最新的测试报告以附件的形式发到指定邮箱
2019/09/20 Python
Python算法中的时间复杂度问题
2019/11/19 Python
Python字节单位转换(将字节转换为K M G T)
2021/03/02 Python
今天学到的CSS最新技术(与图片背景相关)
2012/12/24 HTML / CSS
AC Lens:购买隐形眼镜
2017/02/26 全球购物
德国网上超市:myTime.de
2019/08/26 全球购物
正宗的澳大利亚Ugg靴子零售商:UGG Express
2020/04/19 全球购物
既然说Ruby中一切都是对象,那么Ruby中类也是对象吗
2013/01/26 面试题
教师个人剖析材料
2014/02/05 职场文书
校园运动会广播稿
2014/10/06 职场文书
加班费申请报告
2015/05/15 职场文书
大学宣传委员竞选稿
2015/11/19 职场文书
Java实战之用Swing实现通讯录管理系统
2021/06/13 Java/Android