我目前正在定义正则表达式,以便捕获URL中的参数,如教程中所述。我如何访问参数从URL作为HttpRequest对象的一部分?
我的HttpRequest。GET当前返回一个空的QueryDict对象。
我想学习如何在没有库的情况下做到这一点,这样我就可以更好地了解Django。
我目前正在定义正则表达式,以便捕获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条目会给你一个漂亮的错误:用户匹配查询不存在。 我自己也经历过;希望能有所帮助!
有人会想知道如何在文件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) ]
Url参数可能被request.query_params捕获
使用GET
request.GET["id"]
使用POST
request.POST["id"]