2

次のコードを実行しています。これは 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

ブラウザの URL:

http://localhost:8080/?q=test

ただし、コンソールで次のKeyError Exception が発生します。

File "twi.py", line 12, in render_GET
q = arg['q']
exceptions.KeyError: 'q'

それでも、ブラウザは期待どおりの出力を提供しています。

I am request #3 test

また、コンソールにはコードのデバッグ部分が正しく表示されています。

q ['af']

出力が正しく、キーが適切に存在する場合、何がエラーになる可能性がありますか? dict.get()メソッドを試しましたが、問題が解決しないことに注意してください。

4

2 に答える 2

5

おそらく、ブラウザが 2 つのリクエストを行っているためです。2 番目の要求はおそらくファイルに対するもので、ここではパラメーターfavicon.icoを送信しません。q

要求された URL を印刷してみてください。

関連している

于 2012-08-27T09:54:58.137 に答える
0

奇妙なことに注意してください。コードには が記載されていますq = arg['q']が、エラーメッセージにはp = arg['q']代わりに記載されています。ここに不一致はありませんか、それとも適切なコードを実行していますか?

于 2012-08-27T09:56:14.333 に答える