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

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

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


当前回答

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

在URL配置中:

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

视图中:

list2 = queryparams.split("&")

其他回答

使用GET

request.GET["id"]

使用POST

request.POST["id"]

似乎更推荐使用request.query_params。例如,

当URL是domain/search/?Q =哈哈,你会使用request.query_params。(“问”,没有一个)

https://www.django-rest-framework.org/api-guide/requests/

”的请求。query_params是request.GET的同义词。

为了代码内部清晰,我们建议使用request。query_params而不是Django标准的request.GET。这样做有助于让你的代码更加正确和明显——任何HTTP方法类型都可能包含查询参数,而不仅仅是GET请求。”

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

在URL配置中:

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

视图中:

list2 = queryparams.split("&")

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

views.py

从rest_framework。response import响应 Def update_product(请求,pk): 返回响应({“pk”:pk})

Pk表示主键。

urls . py

从产品。视图导入update_product django。url导入路径 Urlpatterns = [ …, 路径(更新/产品/ < int: pk >”,update_product) ]