有没有办法从使用Urllib2创建的请求中获取标头,或者确认使用urllib2.urlopen发送的HTTP标头?
我正在使用Python实现服务器端过滤以服务KendoUI的Grid组件.
我面临的问题是它默认生成的AJAX调用似乎与Flask的内置URL解析器和Python的urlparse模块不兼容.
这是我遇到问题的查询字符串类型的人为样本: a=b&c=d&foo[bar]=baz&foo[baz]=qis&foo[qis]=bar
这是我要去的结果:
{
'a': 'b',
'c': 'd',
'foo': {
'bar': 'baz',
'baz': 'qis',
'qis': bar'
}
}
Run Code Online (Sandbox Code Playgroud)
不幸的是,request.args如果传递给Flask端点,这就是你从中得到的:
{
'a': 'b',
'c': 'd',
'foo[bar]': 'baz'
'foo[baz]': 'qis'
'foo[qis]': 'bar'
}
Run Code Online (Sandbox Code Playgroud)
更糟糕的是,在实践中,结构可以是几层深.您将列过滤foo到值等于的行的基本调用'bar'将产生以下内容:
{
'filter[logic]': 'and',
'filter[filters][0][value]': 'bar',
'filter[filters][0][field]': 'foo',
'filter[filters][0][operator]': 'eq'
}
Run Code Online (Sandbox Code Playgroud)
我检查了RFC,它要求查询字符串只包含"非分层"数据.虽然我认为它指的是URI所代表的对象,但我没有在规范中找到这种类型的数据结构.
我开始编写一个函数,它将获取params的字典并返回它们所代表的嵌套构造,但我很快就意识到这是一个细微的问题,而且肯定有人在那之前遇到过这个问题.
是否有人知道要么以我想要的方式解析这些参数的模块,要么是一种优雅的解析方法,我可能会忽略它?