样例Python扭曲事件驱动的Web应用程序将请求计数增加2,这是为什么?
问题描述
http://twistedmatrix.com/trac/给出的基本Web服务器的示例代码似乎为每个请求将请求计数器递增2,而不是递增1。
代码:
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")
return "I am request #" + str(self.numberRequests) + "
"
reactor.listenTCP(8080, server.Site(HelloResource()))
reactor.run()
查看代码,您应该能够连接到urlhttp://localhost:8080并查看:
I am request #1
然后刷新页面并查看:
I am request #2
但是,我看到:
I am request #3
再次刷新时,我看到:
I am request #5
因此,从计数器来看,服务器似乎为每个请求调用了两次函数"Render_Get"。我正在使用Python2.7在Windows7上运行这个程序。你知道可能发生了什么吗,或者这是意料之中的行为?
更新:代码运行得很好,是浏览器出了问题。每次页面刷新时,浏览器都会发送一个针对"/"和"/folic.ico"的GET请求,这是递增2的原因,因为Render_Get函数实际上在每次页面刷新时被调用两次。
解决方案
浏览器的行为方式可能出人意料。如果您尝试打印完整的请求,您可能会发现它请求的是"/",也可能是"Favic.ico"。
相关文章