解决websocket在部署到服务器https下无法使用的问题

文章描述了一个在uni-app中使用WebSocket时遇到的问题,当从本地部署到阿里云服务器后,WebSocket无法正常连接。解决方法包括将ws协议改为wss以适应HTTPS环境,以及在Nginx配置中添加相应设置以支持WebSocket代理。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

目录

一、问题

1.1 问题描述

1.2 问题详细描述

二、解决

2.1 https下的链接类型

2.2 修改Nginx的配置

一、问题

1.1 问题描述

一个小项目中使用到了websocket,这个websocket在本地完全是完全正常运行的,不管是前后台的信息通讯 还是 异常报错接收无任何异常,但当把后台代码部署到阿里云服务器后,websocket就再也链接不上了;

(PS: 博主的websocket是应用在uni-app中的,因此使用的是uni-app自带的websocket,这个本质上没有任何区别~)

1.2 问题详细描述

uni-app端的简易websocket代码,大致如下;

// 建立websocket
uni.connectSocket({
  url: Setting.wsUrl
});

// 打开
uni.onSocketOpen(res => {
  console.log('--- 数据通信已打开 ---');
});

uni.onSocketError((res) => {
  console.log('--- 数据通信连接失败,请检查 ---');
});

uni.onSocketMessage((res) => {
  // console.log('收到服务器内容:' + res.data);
  this.resultData(JSON.parse(res.data))
});

当项目启动打开websocket页面,与后台链接成功后前台会打印出:--- 数据通信已打开 ---,

运行后在本地正确打印了结果

但是 当后台文件打包部署到阿里云服务器 后,websocket链接异常,无法正确打印结果;

二、解决

我在这里一共遇到了 两个错误,第一个分别是 https下的链接类型 以及 nginx配置异常 这两个问题,这两个问题解决后,websocket即可正常使用了;

2.1 https下的链接类型

这个问题主要在于链接中的类型写错了,需要把 ws 改写成 wss ,如本地的时候由于使用的是http类型,因此websocket的链接写成了

ws://localhost:5002

但当部署到服务器之后,由于服务器是https的格式,因此ws显然不再合适了,需要改成 wss,即

wss://www.xxxxxx.com/xxx/

放到具体uni-app代码中就是这样

// 建立websocket
uni.connectSocket({
  url: "ws://localhost:5002"
});

// 需要改成 wss 开头的
uni.connectSocket({
  url: "wss://www.xxxx.com/xxxx"
});

这样,就将兼容https下的websocket了;

2.2 修改Nginx的配置

除了改wss外,nginx同样要修改,默认情况下的Nginx是不支持的,因此需要手动去开通这个功能;

首先,找到Nginx的配置文件,然后在配置文件中为需要开通websocket的后台加上这几条语句

proxy_http_version 1.1;
proxy_set_header Upgrade $http_upgrade;
proxy_set_header Connection "upgrade";
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_set_header X-Real-IP $remote_addr;  

以我这边为例,改之前是这样的

server {
	listen 443 ssl;
	server_name www.xxxx.com;
	# access_log  /var/log/nginx/access.log  main;
	# error_log  /var/log/nginx/error.log;

	ssl_certificate      #填写解压的pem文件
	ssl_certificate_key  #填写解压的key文件

	# ssl on;
	ssl_session_cache    shared:SSL:10m;
	ssl_session_timeout  50m;

	ssl_ciphers  HIGH:!aNULL:!MD5;
	ssl_prefer_server_ciphers  on;

	location / {
		root 前台文件;
	}
	location /api/ {
		proxy_pass 后台接口地址;
	}
	location /api2/ {
		proxy_pass 后台接口地址;
    }
}

改完之后如下

server {
	listen 443 ssl;
	server_name www.xxxx.com;
	# access_log  /var/log/nginx/access.log  main;
	# error_log  /var/log/nginx/error.log;

	ssl_certificate      #填写解压的pem文件
	ssl_certificate_key  #填写解压的key文件

	# ssl on;
	ssl_session_cache    shared:SSL:10m;
	ssl_session_timeout  50m;

	ssl_ciphers  HIGH:!aNULL:!MD5;
	ssl_prefer_server_ciphers  on;

	location / {
		root 前台文件;
	}
	location /api/ {
		proxy_pass 后台接口地址;
	}
	location /api2/ {
		proxy_pass 后台接口地址;
		proxy_http_version 1.1;
		proxy_set_header Upgrade $http_upgrade;
		proxy_set_header Connection "upgrade";
		proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
		proxy_set_header X-Real-IP $remote_addr; 
    }
}

加上之后 重启Nginx,websocket即可正常使用了,解决问题;

在C#中,要将WebSocket部署服务器上,你需要一个支持WebSocket的Web服务器,例如IIS(Internet Information Services)或者使用.NET Core的Kestrel服务器。以下是使用.NET Core以及Kestrel服务器部署WebSocket的基本步骤: 1. **创建WebSocket服务**: 在.NET Core应用程序中,首先需要在`Startup.cs`文件的`ConfigureServices`方法中注册`WebSocket`服务。 ```csharp public void ConfigureServices(IServiceCollection services) { services.AddWebSocketManager(); } ``` 2. **配置WebSocket路由**: 在`Startup.cs`的`Configure`方法中,你需要配置WebSocket请求的路由,并映射到一个处理WebSocket连接的类。 ```csharp public void Configure(IApplicationBuilder app, IWebHostEnvironment env) { app.UseWebSockets(); app.MapWebSocketManager("/ws", app.ApplicationServices.GetRequiredService<YourWebSocketHandler>()); } ``` 其中`YourWebSocketHandler`是你自己创建的一个类,它需要实现`WebSocketHandler`接口。 3. **实现WebSocket处理逻辑**: 创建一个继承自`WebSocketHandler`的类,并实现必要的方法来处理WebSocket连接,如`OnConnected`、`OnDisconnected`和`OnReceive`等。 4. **配置服务器**: 对于IIS,确保你的.NET Core应用程序已经正确安装并启用了WebSockets模块。对于Kestrel,上述代码已经配置了WebSocket支持。 5. **部署应用程序**: 将你的.NET Core应用程序发布到服务器上。对于IIS,你可以通过IIS管理器部署;对于Kestrel,你需要确保Kestrel服务器正在运行,并且能够从外部访问。 6. **测试WebSocket连接**: 部署完成后,通过客户端代码测试WebSocket连接是否成功。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Oliver尹

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值