django中url映射规则和服务端响应顺序的实现
作者:edisonfeng 发布时间:2023-04-21 09:58:27
1、django搜索路径
使用 import 语句时,Python 所查找的系统目录清单。
查看方式:
import sys
print sys.path
通常无需关心 Python 搜索路径的设置,Python 和 Django 会在后台自动帮你处理好。
2、url匹配模式
基本结构:
'^需要匹配的url字符串$'
PS:实际上最终完整的url串是http://根路径:端口号/需要匹配的url字符串
系统自动添加的部分'http://根路径:端口号/'
eg:url匹配模式:'^latest_books/$'
最终完整的url字符串:'http://127.0.0.1:8000/latest_books/'
1)^:匹配“子串头”。
eg:
'^latest_books/'
'http://127.0.0.1:8000/latest_books/',
'http://127.0.0.1:8000/latest_books/test1/',
'http://127.0.0.1:8000/latest_books/test2/',
'http://127.0.0.1:8000/latest_books/test1/aaa/'
都会被匹配上。
2)$:匹配“子串结尾”。
eg:
'latest_books/$'
'http://127.0.0.1:8000/latest_books/',
'http://127.0.0.1:8000/updir_1/latest_books/',
'http://127.0.0.1:8000/updir_2/latest_books/'
都会被匹配上。
3)子串末尾是否包含'/'
默认情况下必须添加(django开发者的基本习惯),如果不添加将会出现如下情况:
from django.conf.urls import patterns, url, include
urlpatterns = patterns('',
(r'^latest_books$', 'django_web_app.views.latest_books'),
)
如果子串末尾不想包含'/',可在setting.py中添加设置:APPEND_SLASH=False
但是必须安装了CommonMiddleware才会起作用。
4)手动配置网站“根目录”
在不手动配置网站“根目录”对应“视图函数”的情况下,会出现如下情况:
手动配置“根目录”对应“视图函数”:
a)urls.py
from django.conf.urls import patterns, url, include
urlpatterns = patterns('',
(r'^$','django_web_app.views.home_page'),
(r'^latest_books/$', 'django_web_app.views.latest_books'),
)
b)views.py
def home_page(request):
return render_to_response('home_page.html')
c)home_page.html
<!DOCTYPE html>
<html>
<head>
<title>my home page</title>
</head>
<body>
<h1>This is home page, welcome !</h1>
</body>
</html>
运行结果:
附:正则表达式基础
3、服务端响应url请求的执行顺序
1)项目结构
django_web
__init__.py
settings.py
urls.py
wsgi.py
django_web_app
__init__.py
admin.py
models.py
tests.py
views.py
templates
home_page.html
latest_books.html
manage.py
2)执行顺序
a)启动服务端——python manage.py runserver
获取setting.py文件中的配置,主要包括:
url映射关系文件路径:
ROOT_URLCONF = 'django_web.urls'
页面文件模板路径:
TEMPLATE_DIRS = (
os.path.join(BASE_DIR, 'templates'),
)
数据库配置:
DATABASES = {
'default': {
'ENGINE': 'django.db.backends.mysql',
'NAME': 'django_db',
'USER': 'root',
'PASSWORD': 'feng',
'HOST': '127.0.0.1',
'PORT': '3306',
}
}
b)响应顺序
第一步:浏览器提交请求
http://127.0.0.1:8000/latest_books/
第二步:服务端根据请求的url在urls.py中进行匹配,并找到对应的“视图函数”
第三步:调用对应的“视图函数”
返回一个HttpResponse对象
第四步:django转换HttpResponse对象为一个适合的HTTP response,并返回给页面进行显示
来源:https://www.cnblogs.com/edisonfeng/p/3755136.html
猜你喜欢
- 进行已经矢量化后的字符串数据,可以使用pandas的Series数据对象的map方法。这样,对于未经矢量化的数据也可以先进行数据的矢量化转换
- 从一个字符串开始在CODE上查看代码片派生到我的代码片 >>>time_str='2008-08-08
- 本文实例讲述了Python使用matplotlib和pandas实现的画图操作。分享给大家供大家参考,具体如下:画图在工作再所难免,尤其在做
- 一、为什么使用Python进行网络爬虫?由于Python语言十分简洁,使用起来又非常简单、易学,通过Python 进行编写就像使用英语进行写
- 1.在pycham官网下载安装软件https://www.jetbrains.com/pycharm/download/2.我下载的是64位
- 代码片段一:alert(Function instanceof Object); // truealert(Object instanceo
- 0、项目介绍本篇将会以HandTrackingModule为模块,这里的模块与之前的有所不同,请按照本篇为准,前面的HandTracking
- python对函数库的引用方式1、import <库名> 例如:import turtle 如果需要使用库函数中的函数,需要使用
- 也许还有朋友不太清楚DOMContentLoaded这个事件。简单的说,这个事件就是要在大多数情况下去替代window.onload事件,因
- 表单的验证一直是网页设计者头痛的问题,表单验证类 Validator就是为解决这个问题而写的,旨在使设计者从纷繁复杂的表单验证中解放出来,把
- 思路:队列使用说明:multiprocessing.Queue()#用于进程间通信,单主进程与子进程无法通信(使用进程池时尽量不要使用这个)
- 本文实例讲述了Python实现动态加载模块、类、函数的方法。分享给大家供大家参考,具体如下:动态加载模块: 方式1:系统函数__import
- 前面讲解了使用纯numpy实现数值微分和误差反向传播法的手写数字识别,这两种网络都是使用全连接层的结构。全连接层存在什么问题呢?那就是数据的
- 1.CUDA驱动和CUDA Toolkit对应版本表一:CUDA驱动及CUDA Toolkit最高对应版本最新可查阅官方文档注:驱动是向下兼
- 方法1 自带pytorch自带方法,计算模型参数总量total = sum([param.nelement() for param in m
- 一、状态介绍在了解其他概念之前,我们首先要了解进程的几个状态。在程序运行的过程中,由于 * 作系统的调度算法控制,程序会进入几个状态:就绪,运
- 简介:单例模式可以保证一个类仅有一个实例,并提供一个访问它的全局访问点。适用性于当类只能有一个实例而且客户可以从一个众所周知的访问点访问它,
- IPython是Python的交互式Shell,提供了代码自动补完,自动缩进,高亮显示,执行Shell命令等非常有用的特性。特别是它的代码补
- Python 直接连接mongodb数据库进行查询操作1、安装所需模块使用到的是pymongo模块,安装方法:pip instal
- 通常,由于类别不均衡,需要使用weighted cross entropy loss平衡。def inverse_freq(label):