linux websocket 400错误,websocket报400错误

解决方案

看了下讨论区说的方案,问题出现在nginx的配置文件,需要修改nginx.conf文件。在linux终端中敲入vim /etc/nginx/nginx.conf,找到location这个位置,配置文件如下所示:

server {

listen 80;

server_name school.godotdotdot.com;

charset utf-8;

location / {

proxy_pass http://127.0.0.1:3000;

proxy_set_header Host $host;

proxy_http_version 1.1;

proxy_set_header Upgrade $http_upgrade;

proxy_set_header Connection "upgrade";

proxy_set_header X-Real-IP $remote_addr;

proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;

proxy_connect_timeout 60;

proxy_read_timeout 600;

proxy_send_timeout 600;

}

error_page 500 502 503 504 /50x.html;

location = /50x.html {

root html;

}

}

其中最重要的是下面这三行

proxy_http_version 1.1;

proxy_set_header Upgrade $http_upgrade;

proxy_set_header Connection "upgrade";

其中第一行是告诉nginx使用HTTP/1.1通信协议,这是websoket必须要使用的协议。

第二行和第三行告诉nginx,当它想要使用WebSocket时,响应http升级请求。

下面是一个基于libevent库实现的WebSocket客户端的示例代码: ``` #include <event2/event.h> #include <event2/buffer.h> #include <event2/http.h> #include <event2/http_struct.h> #include <event2/keyvalq_struct.h> #include <event2/bufferevent_ssl.h> #include <openssl/ssl.h> #include <openssl/err.h> static void websocket_readcb(struct bufferevent *bev, void *ctx); static void websocket_eventcb(struct bufferevent *bev, short events, void *ctx); int main(int argc, char **argv) { struct event_base *base; struct bufferevent *bev; struct sockaddr_in sin; SSL_CTX *ssl_ctx; SSL *ssl; base = event_base_new(); memset(&sin, 0, sizeof(sin)); sin.sin_family = AF_INET; sin.sin_addr.s_addr = htonl(INADDR_LOOPBACK); sin.sin_port = htons(8080); bev = bufferevent_socket_new(base, -1, BEV_OPT_CLOSE_ON_FREE); bufferevent_setcb(bev, websocket_readcb, NULL, websocket_eventcb, NULL); bufferevent_enable(bev, EV_READ | EV_WRITE); bufferevent_socket_connect(bev, (struct sockaddr *)&sin, sizeof(sin)); ssl_ctx = SSL_CTX_new(TLSv1_2_client_method()); ssl = SSL_new(ssl_ctx); bufferevent_openssl_set_ssl(bev, ssl, BUFFEREVENT_SSL_CONNECTING); bufferevent_openssl_set_allow_dirty_shutdown(bev, 1); SSL_set_tlsext_host_name(ssl, "localhost"); // 发送WebSocket握手请求 char request[1024]; sprintf(request, "GET /websocket HTTP/1.1\r\n" "Host: localhost:8080\r\n" "Upgrade: websocket\r\n" "Connection: Upgrade\r\n" "Sec-WebSocket-Key: x3JJHMbDL1EzLkh9GBhXDw==\r\n" "Sec-WebSocket-Version: 13\r\n" "\r\n"); bufferevent_write(bev, request, strlen(request)); event_base_dispatch(base); SSL_shutdown(ssl); SSL_free(ssl); SSL_CTX_free(ssl_ctx); bufferevent_free(bev); event_base_free(base); return 0; } static void websocket_readcb(struct bufferevent *bev, void *ctx) { struct evbuffer *input = bufferevent_get_input(bev); char *line = NULL; size_t len = 0; ssize_t nread; while ((nread = evbuffer_get_line(input, &line, &len, EVBUFFER_EOL_CRLF)) > 0) { printf("%s\n", line); free(line); } } static void websocket_eventcb(struct bufferevent *bev, short events, void *ctx) { if (events & BEV_EVENT_CONNECTED) { printf("Connected.\n"); } else if (events & BEV_EVENT_ERROR) { printf("Error.\n"); } else if (events & BEV_EVENT_EOF) { printf("Connection closed.\n"); event_base_loopbreak(bufferevent_get_base(bev)); } } ``` 这个示例代码中,首先创建了一个event_base对象,然后创建了一个bufferevent对象,并设置了回调函数。接着,使用bufferevent_socket_connect函数连接到WebSocket服务器,然后创建了一个SSL_CTX对象和一个SSL对象,并使用bufferevent_openssl_set_ssl函数将SSL对象关联到bufferevent对象上。接下来,发送了一个WebSocket握手请求。最后,调用event_base_dispatch函数进入事件循环。 在事件循环中,如果接收到了数据,就调用websocket_readcb函数进行处理。如果连接建立成功,就输出Connected。如果发生错误,就输出Error。如果连接关闭,就输出Connection closed,并调用event_base_loopbreak函数退出事件循环。 需要注意的是,这个示例代码中使用了OpenSSL库,所以需要链接libssl和libcrypto库。在Linux系统中,可以使用以下命令编译: ``` $ gcc -o websocket-client websocket-client.c -levent -lssl -lcrypto ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值