我正在使用 Django 设置,我可以在其中接收包含查询字符串的 url 作为 GET 的一部分。我希望能够处理查询字符串中提供的数据并返回针对该数据进行调整但不包含 URL 中的查询字符串的页面。
通常我只会使用reverse()
,但我不确定在这种情况下如何应用它。以下是情况的详细信息:
示例网址: .../test/123/?list_options=1&list_options=2&list_options=3
网址.py
urlpatterns = patterns('',
url(r'test/(P<testrun_id>\d+)/'), views.testrun, name='testrun')
)
视图.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 最后仍包含查询字符串。剥离不需要的查询字符串的标准方法是返回 testrun 函数return HttpResponseRedirect(reverse('testrun', args=(testrun_id,)))
。但是,如果我在这里这样做,那么我将通过testrun
函数获得一个无限循环。此外,我不确定原始请求中的 list_options 数据在重定向后是否仍然可用,因为它已从 URL 中删除。
我应该如何解决这个问题?我可以看到,将 list_options 变量的解析移到一个单独的函数中以避免无限递归可能是有意义的,但如果我这样做,我担心它会丢失请求中的 list_options 数据。有没有一种巧妙的方法可以同时将查询字符串从 URL 的末尾删除,并在一个地方返回我想要的页面,这样我就可以避免将事情分成多个函数?
编辑:一点额外的背景,因为有几个“你为什么要这样做?” 查询。
我正在设计的网站是报告我正在开发的软件的各种测试结果。这个特定页面用于报告单个测试的结果,我通常会从更大的测试列表中链接到它。
该list_options
数组是一种在我刚刚来自的列表中指定其他测试的方法。这使我可以使用其他相关测试填充下拉菜单,以便我可以轻松地在它们之间切换。
因此,我很容易最终会传入 15-20 个不同的值并创建巨大的 URL,这是我想避免的。如果我不建议 URL 中的任何其他内容,则该页面旨在具有一组默认的其他测试来填写相关菜单,因此如果我删除list_options
. 如果用户希望直接返回页面,他不会关心列表中的其他测试,因此如果该信息不可用,这不是问题。