с их настройкой c ssl. Мой бэк на laravel 5.5, поэтому вебсокеты тогда шаминились с редисом и нодой, современные библиотеки не подходят, нормальные поддерживают от 5.7.
На локалке работаю вебсокеты как часы, не проблема, но как заливаю на боевой сервак, где подключен ssl, все отваливаеться. Фронт кстати находиться на другом серваке, т.е. еще существует проблема крос-доменных запросов, хотя на уровне приложений все настроено, и я читал что вебсокеты не должны из-за этого блокироваться. Мучаюсь второй день перепробовал многое что, и переводил на wss протокол передачи, но все пока бесполезно, может кто сталкивался с такой проблемой, или сможет подсказать что мне делать. Может Nginx нужно до настроить?
Ответы в Мозиле если настроен по wss протоколу
Firefox не может установить соединение с сервером wss://api.example.com:6001/socket.io/?EIO=3&transport=websocket.
Во время загрузки страницы соединение с wss://api.example.com:6001/socket.io/?EIO=3&transport=websocket было прервано.
Ответ если настроен по обычному https
Запрос из постороннего источника заблокирован: Политика одного источника запрещает чтение удаленного ресурса на https://api.example.com:6001/socket.io/?EIO=3&transport=polling&t=NBIKGUc. (Причина: не удалось выполнить запрос CORS).
Скрипт в самой Ларке
var app = require("express")();
var fs = require("fs");
var options = {
key: fs.readFileSync(__dirname + "/sslcert/privkey.pem", "utf8"),
cert: fs.readFileSync(__dirname + "/sslcert/fullchain.pem", "utf8"),
};
var https = require("https").Server(options, app);
var io = require("socket.io")(https);
var Redis = require("ioredis");
var redis = new Redis();
require("dotenv").config();
redis.subscribe("message", function (err, count) {});
redis.on("message", function (channel, message) {
console.log("Message Recieved: " + message);
message = JSON.parse(message);
io.emit(`${channel}.company.${message.data.company.id}`, message);
});
https.listen(process.env.SOCKET_PORT, function () {
console.log("Listening on Port " + process.env.SOCKET_PORT);
});
Посмотри в сторону proxy_pass
Обсуждают сегодня