运维开发笔记整理-URL配置

时间:2021-12-27 19:57:50

              运维开发笔记整理-URL配置

                                       作者:尹正杰

版权声明:原创作品,谢绝转载!否则将追究法律责任。

一.URL路由

  对于高质量的Web应用来说,使用简洁,优雅的URL的路由是一个非常值得重视的细节。Django让你随心所欲的设计你的URL,不受框架约束。

  为了给一个用用设计URL,你需要创建一个Python模块,通常称为URLconf(URL configuration)。这个模块是纯粹的Python代码,包含URL模式(简单的正则表达式)到Python函数(你的视图)的简单映射。

二.Django如何处理一个请求

1>.Django加载ROOT_URLCONF指定的模块,并寻找可用的urlpatterns,它是djngo.conf.urls.url()实力的一个Python列表;

2>.Django依次匹配每个URL,在与请求的URL匹配的第一个url停下来;

3>.一旦其中的一个正则表达式匹配上,Django将导入并调用给出的视图,它是一个简单的python函数(或者一个基于类的视图)。视图捕获如下参数:

  参数一:一个HttpRequest实例。

  参数二:如果匹配的正则表达式返回了没有命名的组,那么正则表达式匹配的内容将作为位置参数提供给视图。

  参数三:关键字参数由正则表达式匹配的命名组组成,但是可以被django.conf.urls.url()的可选参数kwargs覆盖。

4>.如果没有匹配到正则表达式,或者如果过程这种抛出一个异常,django将调用一个适当的错误处理视图:handler404.handler500,handler403,handler400。

三.URLconf

  URLconf是一个python模块,一个是URL模式(简单正则表达式)到python函数(视图)之间的映射。

四.urlpatterns

  urlpatterns是一个url()实力类型的Python列表

  urlpatterns中的每个正则表达式在第一次访问它们时被编译

五.url函数

def url(regex, view, kwargs=None, name=None):
if isinstance(view, (list, tuple)):
# For include(...) processing.
urlconf_module, app_name, namespace = view
return RegexURLResolver(regex, urlconf_module, kwargs, app_name=app_name, namespace=namespace)
elif callable(view):
return RegexURLPattern(regex, view, kwargs, name)
else:
raise TypeError('view must be a callable or a list/tuple in the case of include().')

def url(regex, view, kwargs=None, name=None):

  regex:一个字符串(原始字符串)或简单的正则表达式。

  view:view参数是一个视图函数或as_view()的结果(基于类的视图)。

  kwargs:传递额外的参数给视图。

  name:url名称。

六.include 示例

  案例一:

urlpatterns = [
url( r'^$', RedirectView.as_view(url="/dashboard/")),
url(r'^dashboard/', include("dashboard.urls")),
url(r'^accounts/', include("accounts.urls")),
url(r'^admin/', admin.site.urls),
]

  案例二:

urlpatterns = [
url(r"^user/", include([
url(r'^list/$', view.userlist, name="user_list"),
url(r'^info/$', view.userinfo, name="userer_inf),
url(r'^modify/', include([
  url(r'status/$',view.modifystatus, name="user_modify_status"),
   ]))
]))
]

七.位置参数

  若要从URL中捕获一个值,只需要在它周围放置一对圆括号。

项目根目录的url.py的配置

from django.conf.urls import url,include
from django.contrib import admin urlpatterns = [
url(r'^admin/', admin.site.urls),
url(r"^dashboard/",include("dashboard.urls")),
]

dashboard的APP中urls.py的配置

#!/usr/bin/env python
#_*_conding:utf-8_*_
#@author :yinzhengjie
#blog:http://www.cnblogs.com/yinzhengjie/tag/python%E8%87%AA%E5%8A%A8%E5%8C%96%E8%BF%90%E7%BB%B4%E4%B9%8B%E8%B7%AF/ from django.conf.urls import url
from . import views urlpatterns = [
url(r'^articles/([0-9]{4})/$', views.year_archive),
url(r'^articles/([0-9]{4})/([0-9]{2})/$', views.month_archive),
url(r'^articles/([0-9]{4})/([0-9]{2})/([0-9]+)/$', views.article_detail),
]

  dashboard的APP中views.py的配置

#!/usr/bin/env python
#_*_conding:utf-8_*_
#@author :yinzhengjie
#blog:http://www.cnblogs.com/yinzhengjie/tag/python%E8%87%AA%E5%8A%A8%E5%8C%96%E8%BF%90%E7%BB%B4%E4%B9%8B%E8%B7%AF/ from django.http import HttpResponsedef year_archive(request,*args,**kwargs):
print("位置参数:",args)
print("关键字参数:",kwargs)
return HttpResponse(args) def month_archive(request,*args,**kwargs):
print("位置参数:", args)
print("关键字参数:", kwargs)
return HttpResponse(args) def article_detail(request,*args,**kwargs):
print("位置参数:", args)
print("关键字参数:", kwargs)
return HttpResponse(args)

  webUI访问效果如下:

运维开发笔记整理-URL配置

八.关键字参数

语法:

(?p<name>pattern)

  name是传给视图参数的名字。

  pattern是一个正则表达式,也是关键字参数的值。案例代码如下,我们将上面的位置参数的代码不要做修改,只需要改动dashboard的配置:

#!/usr/bin/env python
#_*_conding:utf-8_*_
#@author :yinzhengjie
#blog:http://www.cnblogs.com/yinzhengjie/tag/python%E8%87%AA%E5%8A%A8%E5%8C%96%E8%BF%90%E7%BB%B4%E4%B9%8B%E8%B7%AF/ from django.conf.urls import url
from . import views urlpatterns = [
url(r'^articles/(?P<year>[0-9]{4})/$', views.year_archive),
url(r'^articles/(?P<year>[0-9]{4})/(?P<month>[0-9]{2})/$', views.month_archive),
url(r'^articles/(?P<year>[0-9]{4})/(?P<month>[0-9]{2})/(?P<day>[0-9]{2})/$',views.article_detail),
]

  访问webUI在后端可以看到传递的具体参数,如下图所示:

运维开发笔记整理-URL配置

九.额外参数

  URLconfs具有一个钩子,让你传递一个python字典作为额外的参数传递给视图函数。

  django.conf.urls.url()函数可以接受一个可选的第三个参数,它是一个字典,表示想要传递给视图函数的额外关键字参数。

#!/usr/bin/env python
#_*_conding:utf-8_*_
#@author :yinzhengjie
#blog:http://www.cnblogs.com/yinzhengjie/tag/python%E8%87%AA%E5%8A%A8%E5%8C%96%E8%BF%90%E7%BB%B4%E4%B9%8B%E8%B7%AF/ from django.conf.urls import url
from . import views urlpatterns = [
url(r'^blog/(?P<year>[0-9]{4})/$', views.year_archive, {'Name': '尹正杰'}),
]

  上面的代码是dashboard的APP中的urls.py配置,下面的代码是dashboard的APP中的views.py的配置:

#!/usr/bin/env python
#_*_conding:utf-8_*_
#@author :yinzhengjie
#blog:http://www.cnblogs.com/yinzhengjie/tag/python%E8%87%AA%E5%8A%A8%E5%8C%96%E8%BF%90%E7%BB%B4%E4%B9%8B%E8%B7%AF/ from django.http import HttpResponsedef year_archive(request,*args,**kwargs):
print("位置参数:",args)
print("关键字参数:",kwargs)
return HttpResponse(args)

  访问webUI效果如下:

运维开发笔记整理-URL配置

十.URL反向解析

  django给每个URL取了一个名字,存储每个URL和name的映射关系。

  根据Django视图的标识和将要传递给他的参数的值,获取与之关联的URL。这种方式叫做反向解析URL,反响URL匹配,反响URL查询或者简单的URL反查。

#!/usr/bin/env python
#_*_conding:utf-8_*_
#@author :yinzhengjie
#blog:http://www.cnblogs.com/yinzhengjie/tag/python%E8%87%AA%E5%8A%A8%E5%8C%96%E8%BF%90%E7%BB%B4%E4%B9%8B%E8%B7%AF/ from django.conf.urls import url
from . import views urlpatterns = [
url(r"^$",views.index),
url(r"^login/",views.user_login),
url(r'^articles/([0-9]{4})/$', views.year_archive, name='news-year-archive'),
]

  上面代码是dashboard的APP中的urls.py文件,下面的代码是bashboard的APP中的views.py,具体内容如下:

#!/usr/bin/env python
#_*_conding:utf-8_*_
#@author :yinzhengjie
#blog:http://www.cnblogs.com/yinzhengjie/tag/python%E8%87%AA%E5%8A%A8%E5%8C%96%E8%BF%90%E7%BB%B4%E4%B9%8B%E8%B7%AF/ from django.http import HttpResponseRedirectfrom django.core.urlresolvers import reverse
def year_archive(request,*args,**kwargs):
print("===",args)
print(kwargs)
print('news-year-archive')
year = 2006
print(args)
return HttpResponseRedirect(reverse('news-year-archive', args=(year,)))

  如果你使用django的模板代码的话,需要进行如下调用:

<a href="{% url 'news-year-archive' yearvar %}">{{ yearvar }} Archive</a>

运维开发笔记整理-URL配置

   想要了解Django2.0以上版本的url编写规则吗?详情请参考我之前的笔记:《玩转Django2.0》读书笔记-编写URL规则