解决websocket在部署到服务器https下无法使用的问题
创始人
2024-11-04 03:34:50
0

目录

一、问题

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即可正常使用了,解决问题;

相关内容

热门资讯

技巧辅助挂!pokermast... 技巧辅助挂!pokermaster修改器,丹东约战麻将辅助器,演示教程(有挂细节)1、点击下载安装,...
现场直击!wepokerplu... 现场直击!wepokerplus万能挂,丰城双剑新版最强高分攻略,操作教程(有挂方针)1.丰城双剑新...
插件辅助挂!wepoker有辅... 插件辅助挂!wepoker有辅助器吗,乐平包王攻略,学习教程(有挂方略)1、首先打开乐平包王攻略辅助...
据玩家消息!拱趴大菠萝辅助神器... 据玩家消息!拱趴大菠萝辅助神器,多乐跑得快辅助器,机巧教程(证实有挂)1、在拱趴大菠萝辅助神器插件功...
此事备受玩家关注!来玩app破... 此事备受玩家关注!来玩app破解版,h5能反杀吗,绝活教程(有挂详细)1、打开软件启动之后找到中间准...
值得注意的是!aapoker破... 值得注意的是!aapoker破解侠是真的吗,蜀山四川游戏修改工具,经验教程(有挂助手)1、金币登录送...
第三方辅助!wepoker脚本... 第三方辅助!wepoker脚本,广东星悦有外开挂辅助器吗,法门教程(有挂分析)广东星悦有外开挂辅助器...
此事引发广泛关注!德州透视脚本... 此事引发广泛关注!德州透视脚本,崇阳斗棋辅助脚本视频,诀窍教程(的确有挂)暗藏猫腻,小编详细说明崇阳...
黑科技辅助挂!wepoker买... 黑科技辅助挂!wepoker买脚本靠谱吗,情怀七喜游戏辅助,法门教程(有挂方法)1、每一步都需要思考...
方法辅助挂!aapoker怎么... 方法辅助挂!aapoker怎么设置提高好牌几率,蘑菇云辅助使用视频,绝活儿教程(讲解有挂)1、完成蘑...