如何进行Django框架urls.py路由设置-创新互联

如何进行Django框架urls.py路由设置,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。

创新互联主营齐河网站建设的网络公司,主营网站建设方案,APP应用开发,齐河h5重庆小程序开发搭建,齐河网站营销推广欢迎齐河等地区企业咨询

路由系统是把接收到的请求,根据网址进行匹配,指定处理请求的函数或类。

路由系统分类:

    网站框架路由系统一般分为两类,FBV,CBV,Django两者都支持,但有的框架只支持一种。

    FBV(Function Base View ): 函数基于视图,在views.py中,使用函数处理请求。

    CBV(Class Base View):类基于视图,在views.py中,使用处理请求。

URLS.PY文件路由配置

    两个功能,一个是直接转到函数,一个是转到下级urls.py路由

urlpatterns=[     path(r'blog/', blog.views.index),     path(r'bbs/', bbs.views.index) ]

    1、路由规则模块匹配函数url,path,re_path:

      Django 1.XX使用url函数,可以使用正则,可以使用固定字符串

        Django 2.XX以后使用path和re_path,

from django.conf.urls import url        # django 1.XX使用 url from django.conf.urls import url, re_path        # django 2.XX 使用 url和re_path from django.urls import path, re_path        # django 2.1X 以后集成,使用 path和re_path

        url:url()函数传递了四个参数,两个必需:regex和view,以及两个可选:kwargs,和name。也就是正则表达式和视图是两个必填参数。

                1.xx版本--完成正则和固定匹配

                2.xx版本--保留

        path:完成指定字符串或格式的匹配,函数 path() 具有四个参数,两个必须参数:route 和 view,两个可选参数:kwargs 和 name。即路由和视图是必填参数

                2.1x以后版本-- 完成固定匹配

        re_path:正则匹配,path完成不了的匹配

                2.xx版本--原生位置django.conf.urls

                            --后集成位置django.urls

    2、path函数:

        格式:path(匹配规则, views视图函数或类方法, **kwargs, name)

                 匹配规则:不支持正则,但自身提供了五种匹配模式

                       int 匹配0和正整数,如 1230
                       str 匹配任何非空字符串但不包括/,
                       slug 匹配字母、数字以及横杠、下划线组成的字符串。

                       uuid 匹配一个uuid对象,如 075194d3-6885-417e-a8a8-6c931e272f00。(该对象必须包括破折号—,所有字母必须小写)
                       path 匹配所有的字符串 包括/(意思就是path前边和后边的所有)

                      

                 views视图或类方法:app的views.py的方法,或类方法

                 kwargs:向views传递的参数

                 name:后端反向解析,前端根据 name值找到解析路由

    3、path--匹配规则:

         一般分为三种情况,严格匹配,带参匹配,固定格式参数匹配

from django.urls import path, re_path import index.views import pathtest.views urlpatterns = [     path(r'pathtest/', pathtest.views.index),     # r'pathtest/'严格匹配,前端使用pathtest/ 1 2 3传参是会报错。     # The current path, pathtest/ 1 2 3, didn't match any of these.     path(r'pathtest <id_1> <id_2>', pathtest.views.index),     # 使用<>从url中捕获值,pathtest/ 1,pathtest.views.index函数必须接收参数,否则报错,可以是实参,也可以是kwargs     # index() got an unexpected keyword argument 'id_1'     path(r'pathtest <str:book_id>', pathtest.views.index),     # 匹配str型的参数,并命名为book_id,传给views.index函数     # str,int, slug, uuid, path,五种默认的匹配模式 ]

    4、path--views视图或类方法

        指定本条规则,处理请求的views.py的函数(FBV)或类(CBV):

        FBV:urls.py处理请求后,把请求交给函数index,index处理后,返回pathtest.html页面给客户端。

            urls.py

from django.urls import path, re_path import index.views urlpatterns = [     path(r'pathtest <str:book_id>', pathtest.views.index),     # str,int, slug, uuid, path,五种默认的匹配模式 ]

            views.py

from django.shortcuts import render def index(request,*args,**kwargs):     para = []     if kwargs:         for k,v in kwargs.items():             print(k,':',v)     if args:         for i in args:             print(i)     return render(request, 'pathtest.html', {'para': para})

        CBV:

        1、Class需要继承django.views.generic 的View类

        2、URLS.py路由转发到 APP.views.类.as_view()

        3、as_view()是继承View类,不需要自己重写

        4、查看generic\base.py 的as_view方法,看到是通过hasattr进行判断用户请求方式

                通过dispach 执行相对应的请求方法函数

        5、可以通过向 http_method_names注册 新的方法实现自定义

        实例:

        http://127.0.0.1:8000/pathtest1/  显示CBV1

        http://127.0.0.1:8000/pathtest2/  显示CBV2

        URL.py

from django.urls import path, re_path import pathtest.views urlpatterns = [     path(r'pathtest1/', pathtest.views.CBV1.as_view()),     path(r'pathtest2/', pathtest.views.CBV2.as_view()) ]

    APP:pathtest    Views.py

from django.view.generic import class CBV1(View):     def get(self,request,*args,**kwargs):         return HttpResponse('<h2>CBV1</h2>') class CBV2(View):     def get(self,request,*args,**kwargs):         return HttpResponse('<h2>CBV2</h2>')

  5、kwargs:向views传递的参数

            可以向views传递字典型参数,views函数可以使用实参或形参接收,使用形参接收时,通过path函数传递的参数始终在url网址传递的参数前。

        urls.py

urlpatterns = [path(r'pathtest1/<int:url_args>', pathtest.views.CBV1.as_view(),{'since':'O-K'})] # 向views.py传递{'since':'O-K'}

        views.py

class CBV1(View):     def get(self,request, *args, **kwargs):     # 使用实参接收def get(self,request, since, *args, **kwargs):         para = []         if kwargs:             for k,v in kwargs.items():                 print(k,':',v)                 para.append(v)         return HttpResponse('<h2>CBV2{}</h2>'.format(para))          # 访问:http://127.0.0.1:8000/pathtest1/0010  # 网页显示:CBV2['O-K', 10]

      6、name: 定义后,使用{%url 'name值引用'%} ,url代指当前网址。

            views渲染HTML模板{%url 'name值' %}时,根据name值找到urls.py中对应的path路由,

             把path匹配规则字符串替换到 HTML模板的‘name值’

        urls.py

urlpatterns = [ path(r'pathtest1/', pathtest.views.CBV1.as_view()),                # 定义正向路由http://127.0.0.1:8000/pathtest1/访问CBV1 path(r'pathtest2/<int:page_num>', pathtest.views.CBV2.as_view(), name='patht')        # 使用name定义反向 # path(r'lllllllllll/<int:page_num>', pathtest.views.CBV2.as_view(), name='patht')        # 使用name定义反向,匹配规则改变不影响name ]

        views.py

form django.shorsturc import HttpResponse, reverse class CBV2(View):     def get(self,request,page_num, *args, **kwargs):         route_path=reverse('patht', args=(page_num,))         # reverse,转换成际的URL地址,patht是urls里的name值,转换成匹配值         # args:地址里的参数个数,几个就写几个,比如四个(page_num1,page_num2,page_num3,page_num4)         print(route_path)                # 打印出来         return HttpResponse('<h2>CBV2:<br/>page_num:{}</h2>'.format(page_num))      #根据点击的链接不同,获取的返回值也不同 class CBV1(View):     def get(self,request, *args,**kwargs):         return render(request, 'pathtest.html')

        html:

<body> \\使用patht的name名来定义网址路由,后面的123是获取值,所以,三个链接都会执行views的CBV2 <a href="{% url 'patht' 100 %}">num</a> <a href="{% url 'patht' 200 %}">numb/a> <a href="{% url 'patht' 300 %}">numbe</a> </body>

        结果:

            访问:http://127.0.0.1:8000/pathtest1/,点击html里的任何链接都会执行CBV2,因为定义了name值。

      点击任意一个链接,views的route_path:/pathtest2/100

    7、自定义path匹配规则。

path里默认有四个匹配规则,int,str,slug,uuid,path,

            也可以自定义匹配规则,步骤:定义类;使用register_converter 注册;使用。

        urls.py

from django.urls import path, register_reverter import pathtest.views class NumLine: # 第一步,定义类     regex='[-0-9]+'     def to_python(self, value):         return str(value)                //可以进行类型的转换和处理,再返回     def to_url(self, value):         return str(value)                //可以进行类型的转换和处理,再返回 # 第二步,向转换器里注册自定义类,并起个名numline register_reverter(NumLine,'numline')         urlpatterns=[ path(r'pathtest1/', pathtest.views.CBV1.as_view()), path(r'ppppppppp/ <numline:data1> <numline:data2>',pathtest.views.CVB2.as_view(),name='patht') # 使用自义定的numline,匹配参数 ]

    APP:pathtest views.py

from django.shortcuts import HttpResponse, render, reverse from django.views.generic import View class CBV1(View):     def get(self,request):         return render(request,'pathtest.html') class CBV2(View):     def get(self,request,data1, data2):         full_path = reverse('patht',args=(data1,data2))         return HttpResponse('<h2>Full path:{}<br />CBV2:<br/>page_num:{},{}</h2>'.format(full_path, data1, data2))

        pathtest.html

<a href="{% url 'patht' '-0--' 1111 %}">number</a>        //字符型参数传入时,一定要加引号 <a href="{% url 'patht' -2344 2222 %}">number</a>         //这里的-不报错,因为识别成了负数 <a href="{% url 'patht'  3323 3333 %}">number</a>

        结果:访问时,只识别传入的-和0-9,其它参数报错。

    8、path路由分发到APP的urls.py(二级路由)。

使用include方法进行指定,include从django.urls导入

          格式:path(r'pathreg/',include('app.urls'))  ,include('APP名.APP路由文件')

            project:    urls.py

from django.urls import path, include urlparrents=[ path(r'pathreg/',include('pathtest.urls')), ]

            app:     urls.py

from django.urls import path, include from pathtest import views urlparrents=[ path(r'',views.CBV1.as_view()), path(r'index/',views.CBV2.as_view()), ]

            app:        views.py

from django.shortcuts import HttpResponse from django.views.generic import View class CBV2(View):     def get(self,request):         return HttpResponse('<h2>index page</h2>') class CBV1(View):     def get(self, request):         return HttpResponse('<h2>default page<h2>')

结果:http://127.0.0.1:8000/pathreg/,经过project的urls路由文件匹配pathreg,分发到app的urls路由文件,调用CBV1显示default page

          http://127.0.0.1:8000/pathreg/index,经过project的urls路由文件匹配pathreg,分发到app的urls路由文件匹配index,调用CBV1显示index page

    9、re_path:支持正则匹配,其它参数与path一样

            与Django1.xx版本的url功能一样

path(r'', views.CBV1.as_view()), re_path(r'index$', views.CBV2.as_view()), # http://127.0.0.1:8000/pathtest/1111111111111index re_path(r'^index', views.CBV2.as_view()), # http://127.0.0.1:8000/pathtest/index1111111111111 re_path(r'index', views.CBV2.as_view()), # 这才是重点,只要包含连续的index,都会找到DBV2 re_path(r'^[a-zA-Z][_0-9a-zA-Z]{5,9}$', views.CBV2.as_view()) # 匹配以字母开头,后面由数字或下划线或字母组成的最短是6,最长是10个字符的路径 # 注意:{5,9}匹配6,10个字符,因为开头那个不算在{5,9}选项里 # http://127.0.0.1:8000/pathtest/i_d111ex11 匹配 re_path(r'^test/(?P<sid>\d+)$', views.CBV2.as_view()) # 使用()获取url的值 # (?P<name>value)、给获取的值,赋给name的变量,在views函数中使用def test(request,name)或def test(request,**kwargs)

    10、给CBV增加自定义提交方法:

       找到 django.views.generic .View类,

                默认提供了http_method_names列表里的方法,

                as_view函数进行了一些参数等判断,

              最后返回了dispach方法,

                dispach通过反射(getattr)执行相应的函数

            增加自定义提示方法:

            1)向http_method_names列表添加方法名,http_method_names.append('kill')

            2)在app.views.py里定义kill函数

            通过重写dispach方法,给所有方法增加因定操作

    def dispatch(self, request, *args, **kwargs):         print('操作前的操作')         obj = super(Cbv,self).dispatch(request, *args, **kwargs)         print('操作后的操作代码')         return obj

    11、命名空间:、

    namespace,app_name,name

    在project的urls配置namespace(实例命名空间),同时要在跳转APP的urls配置 app_name(应用命名空间)

    主要是实现以APP名区分的路由转发。

    # urls.py:     path('/a/', include('test.urls', namespace='author'))  # namespace   **必须          # test/urls.py:     app_name='dync_name'        # app_name,根据urls的namespace改变。          **必须在url里注册,如果与namespace一样默认指向namespace     re_path(r'^test/(?P<nid>\d+)/$', views.repath, name='detail')             # **name必须     path(r'test/<int:sid>', views.path, name='app01'),                  # views中使用 reverse生成url,reverse('author:index'),-->/a/index/                  # 带参数的:         reverse('author:detail', kwargs={'id':666})        # kwargs里面的key似乎不是很重要,可以变成其它名         reverse('author:app01', args=[sid])                  # 模板带参的:         {%url 'app_name:detail' id=666 %}

看完上述内容,你们掌握如何进行Django框架urls.py路由设置的方法了吗?如果还想学到更多技能或想了解更多相关内容,欢迎关注创新互联行业资讯频道,感谢各位的阅读!

另外有需要云服务器可以了解下创新互联cdcxhl.cn,海内外云服务器15元起步,三天无理由+7*72小时售后在线,公司持有idc许可证,提供“云服务器、裸金属服务器、高防服务器、香港服务器、美国服务器、虚拟主机、免备案服务器”等云主机租用服务以及企业上云的综合解决方案,具有“安全稳定、简单易用、服务可用性高、性价比高”等特点与优势,专为企业上云打造定制,能够满足用户丰富、多元化的应用场景需求。

文章名称:如何进行Django框架urls.py路由设置-创新互联
网页链接:https://www.cdcxhl.com/article30/cdoeso.html

成都网站建设公司_创新互联,为您提供响应式网站面包屑导航外贸建站网站营销电子商务网站制作

广告

声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 创新互联

绵阳服务器托管