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

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

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


当前回答

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

其他回答

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

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

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

你不妨检查一下请求。META字典可以访问很多有用的东西 PATH_INFO, QUERY_STRING

# for example
request.META['QUERY_STRING']

# or to avoid any exceptions provide a fallback

request.META.get('QUERY_STRING', False)

你说它返回空的查询字典

我认为你需要调整你的url接受必要或可选的args或kwargs Django为你提供了处理后悔的所有能力,比如:

url(r'^project_config/(?P<product>\w+)/$', views.foo),

更多信息请访问django-optional-url-parameters

当URL是domain/search/?q=哈哈,你会使用request.GET。(‘问’,”)。

Q是您想要的参数,如果没有找到Q,则“”是默认值。

然而,如果你只是配置你的URLconf**,那么你从regex捕获的信息将作为参数(或命名参数)传递给函数。

如:

(r'^user/(?P<username>\w{0,50})/$', views.profile_page,),

那么在你的视图。py中

def profile_page(request, username):
    # Rest of the method

有人会想知道如何在文件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"

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