我正在定义正则表达式以捕获url中的参数,如教程中所述。 如何从url访问参数作为HttpRequest
对象的一部分? 我的HttpRequest.GET
当前返回一个空的QueryDict
对象。
我想学习如何在没有库的情况下这样做,这样我就能更好地了解Django。
#1楼
我想分享一个可能为您节省一些时间的提示。
如果您打算在urls.py
文件中使用类似的内容:
url(r'^(?P<username>\w+)/$', views.profile_page,),
这基本上意味着www.example.com/<username>
。 请务必将其放置在你的URL条目的结束,否则,很容易造成下面下面的URL条目,即冲突访问它们的人会给你不错的错误: User matching query does not exist.
我自己刚刚体验过它; 希望能帮助到你!
#2楼
当url如下: domain/search/?q=haha
,那么你将使用request.GET.get('q', '')
。
q
是您想要的参数,如果找不到q
则''
是默认值。
但是,如果您只是配置URLconf
,那么regex
中的捕获将作为参数(或命名参数)传递给函数。
如:
(r'^user/(?P<username>\w{0,50})/$', views.profile_page,),
然后在你的views.py
你会有
def profile_page(request, username):
# Rest of the method
#3楼
这不是您要求的,但此代码段有助于管理templates
query_strings
。
#4楼
为了澄清camflan的解释,让我们假设你有
- 规则
url(regex=r'^user/(?P<username>\\w{1,50})/$', view='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
找到请求方法(在本例中为"GET"
,对于提交的表单通常为"POST"
)。 在某些情况下,检查它是否与您期望的相匹配是有用的。
更新:在决定是使用URL路径还是查询参数传递信息时,以下内容可能会有所帮助:
- 使用URL路径来唯一标识资源,例如
/blog/post/15/
(not/blog/posts/?id=15
) - 使用查询参数来改变资源的显示方式,例如
/blog/post/15/?show_comments=1
或/blog/posts/2008/?sort_by=date&direction=desc
- 制作人性化的URL,避免使用ID号并使用日期,类别和/或slu ::
/blog/post/2008/09/30/django-urls/
#5楼
使用GET
request.GET["id"]
使用POST
request.POST["id"]
#6楼
def some_view(request, *args, **kwargs):
if kwargs.get('q', None):
# Do something here ..
#7楼
对于只有request
对象的情况,可以使用request.parser_context['kwargs']['your_param']
#8楼
如果您的网址如下所示,您有两种常用的方法:
https://domain/method/?a=x&b=y
V1:
如果特定密钥是强制性的,您可以使用:
key_a = request.GET['a']
这将返回的值a
,如果项存在,并且异常,如果不。
V2:
如果您的钥匙是可选的:
request.GET.get('a')
您可以尝试不带任何参数,这不会崩溃。 所以你可以用try: except:
来包装它try: except:
并在示例中返回HttpResponseBadRequest()
。 这是一种简单的方法,可以使代码不那么复杂,而无需使用特殊的异常处理。
#9楼
我想在这里添加一些我自己的选项。 有人会想知道如何在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"
#10楼
这些查询目前以两种方式完成。 如果要访问查询参数(GET),可以查询以下内容:
http://myserver:port/resource/?status=1
request.query_params.get('status', None) => 1
如果要访问POST传递的参数,则需要以这种方式访问:
request.data.get('role', None)
使用'get()'访问字典(QueryDict),您可以设置默认值。 在上述情况下,如果未通知“状态”或“角色”,则值为“无”。