用户通过在浏览器的地址栏中输⼊⽹址请求⽹站;对于Django开发的⽹站,都是通过匹配路由找到相应视图来处理⽤户的请求。
一、配置URLconf
1、setting.py文件中
a、指定根路由位置
ROOT_URLCONF = ‘项⽬⼯程同名⽬录.urls’
2、编辑项目中的urls.py文件(根路由)
匹配成功后,include到子应用的urls.py文件中寻址(子路由)
re_path(正则,include('子应用.urls'))
3、创建子应用中的urls.py文件(子路由)
匹配成功后,调用views.py对应的函数
re_path(正则,views.函数名)
4、路由文件urls.py
例1:include子路由
主路由
from django.urls import include, path,re_path
urlpatterns = [
path('admin/', admin.site.urls),
path('film/',include('film.urls')),
]
子路由:
urlpatterns = [
path('hello/',views.helloview),
#正则表达式
re_path('^hello/$',views.helloview)
]
视图:
def helloview(request):
return HttpResponse('helloview')
例2:子路由中有参数
关键字传参:路由中的参数和视图函数中的参数必须保持一致
主路由
from django.urls import include, path,re_path
urlpatterns = [
path('admin/', admin.site.urls),
path('film/',include('film.urls')),
]
子路由:
urlpatterns = [
path('hello/<uname>/',views.helloview),
#正则表达式
re_path(r'^hello/(?P<uname>\w+)/$', views.helloview),
]
视图:
def helloview(request,uname):
return HttpResponse('helloview')
访问url
http://127.0.0.1:8000/film/hello/666/
例3:指定传参类型
主路由
from django.urls import include, path,re_path
urlpatterns = [
path('admin/', admin.site.urls),
path('film/',include('film.urls')),
]
子路由:
只能传递整数型,其他类型的字符会报404,如果不指定数据类型,默认为字符串类型
urlpatterns = [
path('hello/<int:age>/',views.helloview),
]
视图:
def helloview(request,age):
return HttpResponse('helloview')
访问url
http://127.0.0.1:8000/film/hello/666/ 正常访问
http://127.0.0.1:8000/film/hello/abc/ 404
二、API讲解
path(route, view, kwargs=None, name=None)
re_path(route, view, kwargs=None, name=None)
include(module, namespace=None)
route: 匹配路径开始不加 /,末尾加/
route:称为匹配路径
url: http://www.baidu.com/news/?wd=django
url中的news/ 称为请求路径
程序执⾏后是将⽹址中的请求路径和匹配路径进⾏匹配。
三、说明
说明:虽然路由结尾带/能带来上述好处,但是却违背了HTTP中URL表示资源位置路径的设计理念。
是否结尾带/以所属公司定义⻛格为准。
当 Django 找不到所匹配的请求 URL 时,或引发了异常时,Django 会调⽤⼀个错误处理视图。
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
文章由半码博客整理,本文链接:https://www.bmabk.com/index.php/post/74271.html