在request.GET中捕获url参数

我正在定义正则表达式以捕获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.GETQueryDict 。 不进行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),您可以设置默认值。 在上述情况下,如果未通知“状态”或“角色”,则值为“无”。

发布了0 篇原创文章 · 获赞 2 · 访问量 1万+

猜你喜欢

转载自blog.csdn.net/asdfgh0077/article/details/104197818