gpt4 book ai didi

django - 在保留 GET 信息的同时从 django 中的 url 中删除查询字符串

转载 作者:行者123 更新时间:2023-12-04 14:36:28 24 4
gpt4 key购买 nike

我正在处理 Django 设置,我可以在其中接收包含查询字符串的 url 作为 GET 的一部分。我希望能够处理查询字符串中提供的数据并返回针对该数据进行调整但不包含 URL 中的查询字符串的页面。

通常我只会使用reverse(),但我不确定在这种情况下如何应用它。以下是情况的详细信息:

示例网址: .../test/123/?list_options=1&list_options=2&list_options=3

urls.py

urlpatterns = patterns('', 
url(r'test/(P<testrun_id>\d+)/'), views.testrun, name='testrun')
)

views.py

def testrun(request, testrun_id):
if 'list_options' in request.GET.keys():
lopt = request.GET.getlist('list_options')
:
:
[process lopt list]
:
:

:
:
[other processing]
:
:

context = { ...stuff... }
return render(request, 'test_tracker/testview.html', context)

处理示例 URL 时,Django 将返回我想要的页面,但 URL 的末尾仍包含查询字符串。去除不需要的查询字符串的标准方法是使用 return HttpResponseRedirect(reverse('testrun', args=(testrun_id,))) 返回 testrun 函数。但是,如果我在这里这样做,那么我将通过 testrun 函数获得一个无限循环。此外,我不确定原始请求中的 list_options 数据在重定向后是否仍然可用,因为它已从 URL 中删除。

我应该如何解决这个问题?我可以看到将 list_options 变量的解析移出到一个单独的函数中以避免无限递归可能是有意义的,但我担心如果我这样做的话它会丢失请求中的 list_options 数据。有没有一种巧妙的方法可以同时从 URL 末尾删除查询字符串并在一个地方返回我想要的页面,这样我就可以避免将事情分开到多个函数中?

编辑:一些额外的背景,因为有几个“你为什么要这样做?”查询。

我正在设计的网站是为了报告我正在开发的软件的各种测试结果。这个特定页面用于报告单个测试的结果,我通常会从更大的测试列表中链接到它。

list_options 数组是一种在我刚刚来自的列表中指定其他测试的方法。这让我可以用其他相关测试填充下拉菜单,以便我可以轻松地在它们之间切换。

因此,我很容易最终传递 15-20 个不同的值并创建巨大的 URL,我想避免这种情况。如果我没有在 URL 中建议任何其他内容,该页面设计有一组默认的其他测试来填充有问题的菜单,因此如果我删除 list_options 也没什么大不了的。如果用户希望直接返回页面,他不会关心列表中的其他测试,因此即使该信息不可用也不是问题。

最佳答案

首先提醒一句。由于各种原因,这可能不是一个好主意:

  • 书签。想象一下 .../link?q=bar&order=foo 将过滤一些搜索结果并按特定顺序对结果进行排序。如果您将自动删除查询字符串,那么您将有效地禁止用户为特定搜索查询添加书签。
  • 测试。任何时候你添加任何自动化,事情都可能而且很可能会以你从未想象过的方式出错。坚持使用简单而有效的方法总是更好,因为它们被广泛使用,因此不易出错。我将在下面举一个例子。
  • 维护。这不是一个标准的行为模型,因此这将使 future 的开发人员更难维护,因为他们首先必须了解正在发生的事情。

如果您仍然想实现这一点,最简单的方法之一就是使用 session 。这个想法是,当有查询字符串时,将其内容保存到 session 中,然后在没有查询字符串时检索它。例如:

def testrun(request, testrun_id):
# save the get data
if request.META['QUERY_STRING']:
request.session['testrun_get'] = request.GET
# the following will not have querystring hence no infinite loop
return HttpResponseRedirect(reverse('testrun', args=(testrun_id,)))

# there is no querystring so retreive it from session
# however someone could visit the url without the querystring
# without visiting the querystring version first hence
# you have to test for it
get_data = request.session.get('testrun_get', None)
if get_data:
if 'list_options' in get_data.keys():
...
else:
# do some default option
...

context = { ...stuff... }
return render(request, 'test_tracker/testview.html', context)

这应该可以工作,但是它很容易损坏并且没有办法轻松修复它。这应该说明上面的第二个项目符号。例如,假设用户想要并排比较两个搜索查询。因此,他将尝试在同一页面的不同选项卡中访问 .../link?q=bar&order=foo`.../link?q=cat&order=dog浏览器。到目前为止一切顺利,因为每个页面都会打开正确的结果,但是一旦用户尝试刷新第一个打开的选项卡,他就会从第二个选项卡中获得结果,因为这是当前存储在 session 中的内容,并且因为浏览器将有一个两个选项卡的单个 session token 。

即使您会找到其他方法在不使用 session 的情况下实现您想要的效果,我想您也会遇到类似的问题,因为 HTTP 是无状态的,因此您必须将状态存储在服务器上。

实际上有一种方法可以在不破坏大部分功能的情况下做到这一点——在客户端而不是服务器端存储状态。因此,您将拥有一个没有查询字符串的 url,然后让 javascript 查询一些 API,以获取您需要在该页面上显示的任何内容。然而,这将迫使您制作某种 API 并使用一些不完全属于您的问题范围的 javascript。因此,有可能做到干净利落,但这不仅仅涉及使用 Django。

关于django - 在保留 GET 信息的同时从 django 中的 url 中删除查询字符串,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/18131623/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com