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 相关文章推荐
简单介绍Ruby中的CGI编程
Apr 10 Python
Python脚本暴力破解栅栏密码
Oct 19 Python
python、java等哪一门编程语言适合人工智能?
Nov 13 Python
一篇文章读懂Python赋值与拷贝
Apr 19 Python
Python实现拷贝/删除文件夹的方法详解
Aug 29 Python
pandas基于时间序列的固定时间间隔求均值的方法
Jul 04 Python
Python FFT合成波形的实例
Dec 04 Python
python 定义类时,实现内部方法的互相调用
Dec 25 Python
python-sys.stdout作为默认函数参数的实现
Feb 21 Python
Python实现代码块儿折叠
Apr 15 Python
python中def是做什么的
Jun 10 Python
python+requests实现接口测试的完整步骤
Oct 27 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
索尼SONY SRF-S83/84电路分析和打磨
2021/03/02 无线电
adodb与adodb_lite之比较
2006/12/31 PHP
PHP 常用函数库和一些实用小技巧
2009/01/01 PHP
php获取文件大小的方法
2014/02/26 PHP
php网页标题中文乱码的有效解决方法
2014/03/05 PHP
php之static静态属性与静态方法实例分析
2015/07/30 PHP
php+websocket 实现的聊天室功能详解
2020/05/27 PHP
PHP解决高并发的优化方案实例
2020/12/10 PHP
juqery 学习之五 文档处理 插入
2011/02/11 Javascript
javascript时间自动刷新实现原理与步骤
2013/01/06 Javascript
Javascript跨域请求的4种解决方式
2013/03/17 Javascript
JavaScript 开发工具webstrom使用指南
2014/12/09 Javascript
JavaScript中数据结构与算法(五):经典KMP算法
2015/06/19 Javascript
jquery实现页面加载效果
2017/02/21 Javascript
关于Node.js的events.EventEmitter用法介绍
2017/04/01 Javascript
JavaScript简单实现合并两个Json对象的方法示例
2017/10/16 Javascript
基于js中style.width与offsetWidth的区别(详解)
2017/11/12 Javascript
vue-baidu-map 进入页面自动定位的解决方案(推荐)
2018/04/28 Javascript
微信小程序使用form表单获取输入框数据的实例代码
2018/05/17 Javascript
基于webpack4搭建的react项目框架的方法
2018/06/30 Javascript
[01:41]DOTA2超级联赛专访YYF 称一辈子难忘TI2
2013/05/28 DOTA
python统计文本文件内单词数量的方法
2015/05/30 Python
python遍历一个目录,输出所有的文件名的实例
2018/04/23 Python
python: 自动安装缺失库文件的方法
2018/10/22 Python
详解爬虫被封的问题
2019/04/23 Python
python保存字典和读取字典的实例代码
2019/07/07 Python
自适应线性神经网络Adaline的python实现详解
2019/09/30 Python
乌克兰香水和化妆品网站:Notino.ua
2018/03/26 全球购物
TCP/IP的分层模型
2013/10/27 面试题
大学生党课思想汇报
2013/12/29 职场文书
经济职业学院毕业生自荐书
2014/03/17 职场文书
酒店餐厅2014重阳节活动策划方案
2014/09/16 职场文书
工商局副局长个人对照检查材料
2014/09/25 职场文书
幼儿园国庆节活动总结
2015/03/23 职场文书
mysql 带多个条件的查询方式
2021/06/05 MySQL
python自动化测试通过日志3分钟定位bug
2021/11/20 Python