Python的一個新web框架Tornado的初步了解
Python的一個新web框架,由非死book開源。不得不說,品牌效應啊,只要是非死book開源的項目,沒有不好用的。Tornado可以說是好用到了極致,從打開官方頁面開始了解,到搭建一個web服務器,只用了10分鐘。
另外,Tornado支持websocket通訊,和前幾天看的通過Netty支持Websocket相比,Tornado的操作要顯得簡單得更多。
下載地址:http://www.tornadoweb.org/en/stable/
安裝步驟:
tar xvzf tornado-3.0.1.tar.gz cd tornado-3.0.1 python setup.py build sudo python setup.py install
服務器代碼如下:
import tornado.ioloop import tornado.web import tornado.websocket class MainHandler(tornado.web.RequestHandler): def get(self): self.write("Hello, world") class MainHandler2(tornado.web.RequestHandler): def get(self): self.write("This is a test") class EchoWebSocket(tornado.websocket.WebSocketHandler): def open(self): print "WebSocket opened" def on_message(self, message): self.write_message(u"You said: " + message) def on_close(self): print "WebSocket closed" application = tornado.web.Application([ (r"/", MainHandler), (r"/test", MainHandler2), (r"/websocket", EchoWebSocket), ]) if __name__ == "__main__": application.listen(8888) tornado.ioloop.IOLoop.instance().start()
只需要在application中注冊url對應的handler即可,對于websocket,只要讓handler繼承自tornado.websocket.WebSocketHandler。
然后用以下代碼測試:
<html><head><title>Web Socket Client</title></head> <body> <script type="text/javascript"> var socket; if (!window.WebSocket) { window.WebSocket = window.MozWebSocket; } // Javascript Websocket Client if (window.WebSocket) { socket = new WebSocket("ws://localhost:8888/websocket"); socket.onmessage = function(event) { var ta = document.getElementById('responseText'); ta.value = ta.value + '\n' + event.data }; socket.onopen = function(event) { var ta = document.getElementById('responseText'); ta.value = "Web Socket opened!"; }; socket.onclose = function(event) { var ta = document.getElementById('responseText'); ta.value = ta.value + "Web Socket closed"; }; } else { alert("Your browser does not support Web Socket."); } // Send Websocket data function send(message) { if (!window.WebSocket) { return; } if (socket.readyState == WebSocket.OPEN) { socket.send(message); } else { alert("The socket is not open."); } } </script> <h3>Send :</h3> <form onsubmit="return false;"> <input type="text" name="message" value="Hello World!"/><input type="button" value="Send Web Socket Data" onclick="send(this.form.message.value)" /> <h3>Receive :</h3> <textarea id="responseText" style="width:500px;height:300px;"></textarea> </form> </body> </html>
效果如下:
本文由用戶 jopen 自行上傳分享,僅供網友學習交流。所有權歸原作者,若您的權利被侵害,請聯系管理員。
轉載本站原創文章,請注明出處,并保留原始鏈接、圖片水印。
本站是一個以用戶分享為主的開源技術平臺,歡迎各類分享!