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

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

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


当前回答

这些查询目前有两种方式。如果您想访问查询参数(GET),您可以查询以下命令:

http://myserver:port/resource/?status=1
request.query_params.get('status', None) => 1

如果你想访问POST传递的参数,你需要通过这种方式访问:

request.data.get('role', None)

使用'get()'访问字典(QueryDict),可以设置一个默认值。在上述情况下,如果没有通知'status'或'role',则值为None。

其他回答

我想分享一个可以节省你时间的小窍门。 如果你计划在urls.py文件中使用这样的东西:

url(r'^(?P<username>\w+)/$', views.profile_page,),

这意味着www.example.com/<用户名>。一定要把它放在URL条目的末尾,否则,它很容易与下面的URL条目发生冲突,即访问其中一个URL条目会给你一个漂亮的错误:用户匹配查询不存在。 我自己也经历过;希望能有所帮助!

def some_view(request, *args, **kwargs):
    if kwargs.get('q', None):
        # Do something here ..

如果你只能访问视图对象,那么你可以通过这种方式获取URL路径中定义的参数:

view.kwargs.get('url_param')

如果你只有访问请求对象的权限,使用下面的方法:

request.resolver_match.kwargs.get('url_param')

在Django 3上测试。

为了澄清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/

有人会想知道如何在文件urls.py中设置路径,例如

domain/search/?q=CA

这样我们就可以调用查询。

事实上,没有必要在文件urls.py中设置这样的路由。你只需要在urls.py中设置路由:

urlpatterns = [
    path('domain/search/', views.CityListView.as_view()),
]

当你输入http://servername:port/domain/search/?q=CA。查询部分'?q=CA'将自动保留在你可以引用的哈希表中

request.GET.get('q', None).

下面是一个例子(文件views.py)

class CityListView(generics.ListAPIView):
    serializer_class = CityNameSerializer

    def get_queryset(self):
        if self.request.method == 'GET':
            queryset = City.objects.all()
            state_name = self.request.GET.get('q', None)
            if state_name is not None:
                queryset = queryset.filter(state__name=state_name)
            return queryset

此外,当你在URL中写入查询字符串时:

http://servername:port/domain/search/?q=CA

不要将查询字符串用引号括起来。例如,

http://servername:port/domain/search/?q="CA"