尝试使用使用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的异步调用?
此外,如果您知道任何类似的例子,请分享。
我总是告诉那些尝试使用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。
相关参考: