从使用emscripten编译的c ++连接websocket的问题

问题描述 投票:1回答:1

尝试使用使用emscripten编译的c ++代码连接到websocket(poco-1.9.0 samples \ WebSocketServer)。使用已编译的boost 1.69和一个常见示例连接到套接字。

boost::asio::ssl::context ctxt(context::sslv23_client); 
ctxt.set_verify_mode(boost::asio::ssl::verify_none);

boost::asio::io_service svc;
tcp::resolver resolver(svc);
tcp::resolver::query query("127.0.0.1", "9980", 
    boost::asio::ip::resolver_query_base::numeric_service);

tcp::resolver::iterator i = resolver.resolve(query, ec);

boost::asio::ssl::stream<tcp::socket> s(svc, ctxt);
s.lowest_layer().connect(*i, ec); 
s.handshake(boost::asio::ssl::stream<tcp::socket>::client, ec);

服务器输出如下

Request from 127.0.0.1:58152: GET / HTTP/1.1
Host: 127.0.0.1:9980
Connection: Upgrade
Pragma: no-cache
Cache-Control: no-cache
Upgrade: websocket
Origin: http://127.0.0.1:8887
Sec-WebSocket-Version: 13
Sec-WebSocket-Protocol: binary
WebSocket connection established.
Frame received (length=0, flags=0x0).
WebSocket connection closed.

但是,此代码在握手后挂起。可以这样使用,还是必须使用asio的异步调用?

此外,如果您知道任何类似的例子,请分享。

c++ boost emscripten webassembly
1个回答
0
投票

我总是告诉那些尝试使用WebAssembly的人......

WebAssembly(在浏览器上下文中)是JavaScript。

即使您使用Emscripten在C / C ++中编码,编译的WebAssembly字节码也可以在浏览器的JavaScript引擎(如V8)中运行。这意味着WASM代码除了JavaScript API之外没有任何特殊的低级API。每个系统级函数都使用JavaScript进行模拟。

这是什么意思?低级套接字控制(例如设置SSL版本和SSL握手)没有意义,因为您的WASM代码只能使用JavaScript WebSocket API进行网络连接,因此套接字由浏览器处理,而不是WASM代码。

相反,您可以使用普通的BSD套接字。 Emscripten会将BSD套接字转换为JavaScript WebSocket。换句话说,你根本不能使用Poco库。

像这样:

struct sockaddr_in addr;
ing res;
int fd = socket(PF_INET, SOCK_STREAM, IPPROTO_TCP);
unsigned long nonblocking = 1;
fcntl(fd, F_SETFL, O_NONBLOCK);
memset(&addr, 0, sizeof(addr));
addr.sin_family = AF_INET;
addr.sin_port = htons(9980);
if (inet_pton(AF_INET, "127.0.0.1", &addr.sin_addr) != 1) {
  perror("inet_pton failed");
  finish(EXIT_FAILURE);
}
res = connect(server.fd, (struct sockaddr *)&addr, sizeof(addr));

顺便说一下,你只能使用异步(非阻塞)套接字操作,因为它是JS websockets。

相关参考:

© www.soinside.com 2019 - 2024. All rights reserved.