我目前正在定义正则表达式,以便捕获URL中的参数,如教程中所述。我如何访问参数从URL作为HttpRequest对象的一部分?
我的HttpRequest。GET当前返回一个空的QueryDict对象。
我想学习如何在没有库的情况下做到这一点,这样我就可以更好地了解Django。
我目前正在定义正则表达式,以便捕获URL中的参数,如教程中所述。我如何访问参数从URL作为HttpRequest对象的一部分?
我的HttpRequest。GET当前返回一个空的QueryDict对象。
我想学习如何在没有库的情况下做到这一点,这样我就可以更好地了解Django。
当前回答
似乎更推荐使用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看起来像这样:
https://domain/method/?a=x&b=y
版本1:
如果一个特定的键是强制性的,你可以使用:
key_a = request.GET['a']
如果键存在,则返回值为a,如果不存在则返回异常。
版本2:
如果你的键是可选的:
request.GET.get('a')
你可以尝试没有任何参数,这不会崩溃。 所以你可以用try: except:来包装它,并返回HttpResponseBadRequest()。 这是一种使代码不那么复杂的简单方法,不需要使用特殊的异常处理。
有人会想知道如何在文件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"
Url参数可能被request.query_params捕获
这是另一个可以实现的替代解决方案:
在URL配置中:
urlpatterns = [path('runreport/<str:queryparams>', views.get)]
视图中:
list2 = queryparams.split("&")
使用GET
request.GET["id"]
使用POST
request.POST["id"]