WebSockets в Twisted

3,666 views

Published on

Published in: Technology
0 Comments
3 Likes
Statistics
Notes
  • Be the first to comment

No Downloads
Views
Total views
3,666
On SlideShare
0
From Embeds
0
Number of Embeds
54
Actions
Shares
0
Downloads
22
Comments
0
Likes
3
Embeds 0
No embeds

No notes for slide

WebSockets в Twisted

  1. 1. WebSockets в Twisted Кириллов Сергей Конференция PyKyiv 30 января 2010 г. Киев
  2. 2. Сначала был HTTP 1990
  3. 3. Ajax 1999
  4. 4. Comet 2004
  5. 5. WebSockets 2010
  6. 6. WebSockets — стандартный протокол для асинхронного взаимодействия с браузером
  7. 7. Пример WebSocket URL <ul><li>ws://127.0.0.1:5555/path </li></ul><ul><li>wss://127.0.0.1:5555/path ( TLS) </li></ul>
  8. 8. WebSockets Handshake <ul><li>Запрос </li></ul><ul><li>GET /demo HTTP/1.1 </li></ul><ul><li>Upgrade: WebSocket </li></ul><ul><li>Connection: Upgrade </li></ul><ul><li>Host: example.com </li></ul><ul><li>Origin: http://example.com </li></ul><ul><li>WebSocket-Protocol: sample </li></ul><ul><li>Ответ </li></ul><ul><li>HTTP/1.1 101 Web Socket Protocol Handshake </li></ul><ul><li>Upgrade: WebSocket </li></ul><ul><li>Connection: Upgrade </li></ul><ul><li>WebSocket-Origin: http://example.com </li></ul><ul><li>WebSocket-Location: ws://example.com/demo </li></ul><ul><li>WebSocket-Protocol: sample </li></ul>
  9. 9. Поддержка браузерами <ul><li>Google Chrome </li></ul><ul><li>Последние билды Safari </li></ul><ul><li>Mozilla Firefox ( запланирован на релиз 3.7) </li></ul>
  10. 10. Мало? Firefox 3.5, IE6, IE7, IE8
  11. 11. web-socket-js http://github.com/gimite/web-socket-js
  12. 12. Ок, круто. Как это всё прикрутить к Python?
  13. 13. Twisted!
  14. 14. Twisted <ul><li>Официальная поддержка в разработке </li></ul><ul><li>http://bitbucket.org/rushman/tx-websockets/ </li></ul>
  15. 15. Chat Server (41 строка)
  16. 16. HTML -страница клиент (51 строка) <ul><li>var myWebSocket = new WebSocket(&quot;ws://192.168.1.100:8007/&quot;); </li></ul><ul><li>myWebSocket.onopen = function(evt) { $('#status').removeClass('disconnected').addClass('connected').text('WebSocket is connected :)'); </li></ul><ul><li>}; </li></ul><ul><li> </li></ul><ul><li>myWebSocket.onmessage = function(evt) { </li></ul><ul><li>$('<li/>').text(evt.data).appendTo('#log'); </li></ul><ul><li>$(&quot;body&quot;).stop(true, false).animate({ scrollTop: $(document).height() }, &quot;slow&quot;); </li></ul><ul><li>}; </li></ul><ul><li> </li></ul><ul><li>myWebSocket.onclose = function(evt) { </li></ul><ul><li>$('#status').removeClass('connected').addClass('disconnected').text('WebSocket is disconnected :('); </li></ul><ul><li>}; </li></ul><ul><li> </li></ul><ul><li>$('#form').submit(function(evt) { </li></ul><ul><li>evt.preventDefault(); </li></ul><ul><li>myWebSocket.send($('#data').val()); </li></ul><ul><li>$('#data').val(''); </li></ul><ul><li>}); </li></ul>
  17. 17. Демо! http://bit.ly/wschat
  18. 18. Всем спасибо  … а ещё мы ищем « головастиков »

×