我目前正在定义正则表达式,以便捕获URL中的参数,如教程中所述。我如何访问参数从URL作为HttpRequest对象的一部分?

我的HttpRequest。GET当前返回一个空的QueryDict对象。

我想学习如何在没有库的情况下做到这一点,这样我就可以更好地了解Django。


当前回答

对于只有request对象的情况,可以使用request.parser_context['kwargs']['your_param']

其他回答

这是另一个可以实现的替代解决方案:

在URL配置中:

urlpatterns = [path('runreport/<str:queryparams>', views.get)]

视图中:

list2 = queryparams.split("&")

对于只有request对象的情况,可以使用request.parser_context['kwargs']['your_param']

使用GET

request.GET["id"]

使用POST

request.POST["id"]

为了澄清camflan的解释,让我们假设你有

规则的url (regex = r ' ^用户/ (? P <用户名> \ w 50{1,}) / $”,查看=“views.profile_page”) http://domain/user/thaiyoshi/?message=Hi的传入请求

URL分派器规则将捕获部分URL路径(这里是“user/thaiyoshi/”),并将它们与请求对象一起传递给视图函数。

查询字符串(这里message=Hi)被解析,参数被存储为request.GET中的QueryDict。不对HTTP GET参数进行进一步的匹配或处理。

这个视图函数将使用从URL路径和查询参数中提取的两个部分:

def profile_page(request, username=None):
    user = User.objects.get(username=username)
    message = request.GET.get('message')

作为旁注,您将在request.method中找到request方法(在本例中为“GET”,对于提交的表单通常为“POST”)。在某些情况下,检查它是否符合您的期望是有用的。

更新:当决定是否使用URL路径或查询参数来传递信息时,以下操作可能会有所帮助:

使用URL路径来唯一标识资源,例如/blog/post/15/(不是/blog/posts/?id=15) 使用查询参数来改变资源的显示方式,例如/blog/post/15/?Show_comments =1或/blog/posts/2008/?sort_by = date&direction = desc 为了创建人性化的url,避免使用ID号,使用日期、类别和/或段码:/blog/post/2008/09/30/django-urls/

如果你不知道参数的名称,想要使用它们,你可以使用request.GET.keys()或dict(request.GET)函数