我有一个带有frameWork Symfony的实时Web应用程序。我需要将数据从客户端发送到webscket服务器。所以我试试这个:
var conn = new WebSocket('ws://127.0.0.1:8080');
console.log (conn);
conn.onopen = function (e) {
console.log ("Connection established!");
conn.send("xoxo");
};
它没有显示任何错误,在服务器端我有这个: 服务器代码:
$app=new AggregateApplication();
$loop = \React\EventLoop\Factory::create();
$context = new \React\ZMQ\Context($loop);
$pull = $context->getSocket(\ZMQ::SOCKET_PULL);
$pull->bind('tcp://127.0.0.1:5555');
$pull->on('message', array($app, 'EditMessage'));
$webSock = new \React\Socket\Server($loop);
$webSock->listen(8080, '127.0.0.1');
$handler = $this->getContainer()->get('session.handler');
$server=new \Ratchet\Wamp\WampServer($app);
$server = new SessionProvider($server, $handler);
$webServer = new \Ratchet\Server\IoServer(new \Ratchet\WebSocket\WsServer($server),$webSock);
$loop->run();
这是我的应用代码:
class AggregateApplication implements WampServerInterface {
protected $clients;
protected $comming;
public function __construct() {
$this->clients = array();
$this->comming = array();
}
public function onOpen(ConnectionInterface $conn){
$this->clients[array_shift($this->comming)]=$conn;
echo "New connection! ".array_shift($this->comming)." ({$conn->resourceId})\n";
}
public function onCall(ConnectionInterface $conn, $id, $topic, array $params){
}
public function onSubscribe(ConnectionInterface $conn, $topic){
echo "onSubscribe";
}
public function onUnSubscribe(ConnectionInterface $conn, $topic){
}
public function onPublish(ConnectionInterface $conn, $topic, $event, array $exclude, array $eligible){
}
public function onClose(ConnectionInterface $conn) {
unset($this->clients[array_search($conn, $this->clients)]);
echo 'close connection ';
}
public function onError(ConnectionInterface $conn, \Exception $e) {
}
}
我找不到的问题是我会抓住客户发来的消息吗?
答案 0 :(得分:1)
您的邮件不符合WAMP standard。查看AutobahnJS以获取客户端连接。另请查看Ratchet Push Integration Tutorial,其中包含一个功能示例。
答案 1 :(得分:0)
请记住,WAMP standard只是推送集成(ZMQ)的建议。您可以使用纯javascript 在客户端处理此机制,而不使用任何AutobahnJS
等图书馆服务器代码:
// Create loop for listen
$loop = React\EventLoop\Factory::create();
$pusher = new Pusher;
// Listen for the web server to make a ZeroMQ push after an ajax request
$context = new React\ZMQ\Context($loop);
$pull = $context->getSocket(ZMQ::SOCKET_PULL);
$pull->bind('tcp://127.0.0.1:5555'); // Binding to 127.0.0.1 means the only client that can connect is itself
$pull->on('message', array($pusher, 'onBlogEntry'));
// Set up our WebSocket server for clients wanting real-time updates
$webSock = new React\Socket\Server($loop);
$webSock->listen(8080, '127.0.0.1'); // Binding to 127.0.0.1 means remotes can connect
$webServer = new Ratchet\Server\IoServer(
new Ratchet\WebSocket\WsServer(
$pusher
), $webSock
);
// run server for listen websocket base connection
$loop->run();
您的应用程序代码不需要主题类(WAMP类)作为消息模式,因此它不需要使用WAMP和AutobahnJS。
应用代码例如:
class Pusher implements MessageComponentInterface {
public function __construct() {
$this->clients = new \SplObjectStorage;
}
public function onOpen(ConnectionInterface $conn) {}
public function onMessage(ConnectionInterface $from, $msg) {}
public function onClose(ConnectionInterface $conn) {}
public function onError(ConnectionInterface $conn, \Exception $e) {}
public function onBlogEntry($entry) {}
}
答案 2 :(得分:0)
观看以下幻灯片。
<强> http://wamp-proto.org/ 强>
客户端可以通过远程过程调用(RPC)与服务器通信。
如果您使用AutobahnJS(http://autobahn.ws/js/),则可以在您的客户端中添加。
session.call('myaction', [mydata]).then(
function (res) {
console.log("Result:", res);
}
);
在您的Pusher课程中,您使用以下函数捕获客户端发送的消息。
public function onCall(ConnectionInterface $conn, $id, $topic, array $params)
{
// do what you want
}