问题:除了使用gevent-socketio和Socket.io.js和bottle实现之外,与此链接 中的示例类似的解决方案是什么?我正在寻找最小的解决方案,它可以简单地将一些流量从客户端传递到服务器,然后使用 gevent-socketio、Socket.io.js 和瓶子返回到客户端。
背景:我开发了一个简单的 web 应用程序,它为服务器上的远程自定义 shell (cli) 提供了一个基于 web 的终端。浏览器(客户端)从表单输入字段收集 shell 命令,通过 web-socket 将命令传递给通过处理程序gevent.pywsgi.WSGIServer
处理请求的geventwebsocket.WebSocketHandler
处理程序,该处理程序将命令提供给 shell,同时通过套接字将输出异步返回到 textarea 字段在客户端浏览器中的表单中。这是基于瓶子团队提供的一个很好的小例子:
http://bottlepy.org/docs/dev/async.html#finally-websockets
此处提供冗余:
example_server.py:
from bottle import request, Bottle, abort
app = Bottle()
@app.route('/websocket')
def handle_websocket():
wsock = request.environ.get('wsgi.websocket')
if not wsock:
abort(400, 'Expected WebSocket request.')
while True:
try:
message = wsock.receive()
wsock.send("Your message was: %r" % message)
except WebSocketError:
break
from gevent.pywsgi import WSGIServer
from geventwebsocket import WebSocketHandler, WebSocketError
server = WSGIServer(("0.0.0.0", 8080), app,
handler_class=WebSocketHandler)
server.serve_forever()
客户端.html:
<!DOCTYPE html>
<html>
<head>
<script type="text/javascript">
var ws = new WebSocket("ws://example.com:8080/websocket");
ws.onopen = function() {
ws.send("Hello, world");
};
ws.onmessage = function (evt) {
alert(evt.data);
};
</script>
</head>
</html>
动机: 我现有的应用程序在最新版本的 Firefox 和 Chrome 中运行良好。不存在 IE 支持,Safari 兼容性中等。我最终正在寻找一种跨浏览器解决方案来在客户端和服务器之间通信 shell 命令和输出。如果我有一个简单的瓶子例子,我想我可以更快地前进。
顺便说一句,我查看了gevent-socketio 示例,甚至还有一个 bottle 示例,但所有这些示例都与上面的简单示例相差太大,无法在应用程序上实现飞跃。(gevent-socketio 示例看起来与我熟悉的瓶子应用程序完全不同。而且,瓶子示例实际上并没有展示如何与客户端通信。)
谢谢!:)