样例Python扭曲事件驱动的Web应用程序将请求计数增加2,这是为什么?

2022-04-18 00:00:00 python twisted

问题描述

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"。

相关文章