我正在运行以下代码;它来自Twisted Framework的示例列表,属于Web服务器。
from twisted.web import server, resource
from twisted.internet import reactor
class HelloResource(resource.Resource):
isLeaf = True
numberRequests = 0
def render_GET(self, request):
self.numberRequests += 1
request.setHeader("content-type", "text/plain")
arg = request.args
q = arg['q']
#Added for debugging
for key, value in arg.iteritems():
print key, value
return "I am request #" + str(self.numberRequests) + " " + q[0] + "\n"
reactor.listenTCP(8080, server.Site(HelloResource()))
reactor.run()
执行:
[user@localhost pytwist]$ python twi.py
浏览器网址:
http://localhost:8080/?q=test
但是,我在控制台上收到以下KeyError异常:
File "twi.py", line 12, in render_GET
q = arg['q']
exceptions.KeyError: 'q'
然而,浏览器正在给出预期的输出:
I am request #3 test
此外,控制台正确显示代码的调试部分:
q ['af']
如果输出正确并且密钥存在正确,那么可能是什么错误?请注意,我尝试了dict.get()
方法,但问题仍然存在。
答案 0 :(得分:5)
这可能是因为您的浏览器发出了两个请求。第二个请求可能是favicon.ico
文件,此处它不会发送q
参数。
尝试打印请求的网址。
相关强>
答案 1 :(得分:0)
我注意到一些奇怪的内容:您的代码提到了q = arg['q']
,而错误消息却指出了p = arg['q']
。这里不存在不匹配,或者您是否正在执行好的代码?