В настоящее время у меня на сервере Rapberry Pi работает сервер Apache, который позволяет мне включать и выключать светодиод с любого устройства в моей домашней сети.Я использую веб-сокеты для связи с сервером, работающим на моем Raspberry Pi со страницы HTML.
Следующим шагом, который я хотел бы предпринять, является управление Raspberry Pi с устройства, не подключенного к моей домашней сети, и я совершенно не знаю, как этого добиться.Мне было интересно, смогу ли я подключить удаленный сервер к серверу Raspberry Pi, если бы он был размещен на таком сайте, как Heroku, но я никогда не делал ничего подобного раньше.
Вот мой текущий код, выполняющий / управляющий локальным сервером Apache:
server.js:
var http = require('http').createServer(handler); //require http server, and create server with function handler()
var fs = require('fs'); //require filesystem module
var io = require('socket.io')(http) //require socket.io module and pass the http object (server)
http.listen(8080); //listen to port 8080
function handler (req, res) { //create server
fs.readFile(__dirname + '/public/index.html', function(err, data) { //read file index.html in public folder
if (err) {
res.writeHead(404, {'Content-Type': 'text/html'}); //display 404 on error
return res.end("404 Not Found");
}
res.writeHead(200, {'Content-Type': 'text/html'}); //write HTML
res.write(data); //write data from index.html
return res.end();
});
}
io.sockets.on('connection', function (socket) {// WebSocket Connection
var lightvalue = 0; //static variable for current status
socket.on('light', function(data) { //get light switch status from client
lightvalue = data;
if (lightvalue) {
console.log(lightvalue); //turn LED on or off, for now we will just show it in console.log
}
});
});
Index.html:
<!DOCTYPE html>
<html>
<body>
<h1>Control LED light</h1>
<p><input type="checkbox" id="light"></p>
<script src="https://cdnjs.cloudflare.com/ajax/libs/socket.io/2.0.3/socket.io.js"></script> <!-- include socket.io client side script -->
<script>
var socket = io(); //load socket.io-client and connect to the host that serves the page
window.addEventListener("load", function(){ //when page loads
var lightbox = document.getElementById("light");
lightbox.addEventListener("change", function() { //add event listener for when checkbox changes
socket.emit("light", Number(this.checked)); //send button status to server (as 1 or 0)
});
});
socket.on('light', function (data) { //get button status from client
document.getElementById("light").checked = data; //change checkbox according to push button on Raspberry Pi
socket.emit("light", data); //send push button status to back to server
});
</script>
</html>
</body>
</html>
Перед этим проектом я использовал цикл Python while для постоянного чтения значений базы данных Firebase в реальном времени.Светодиод включался и выключался в зависимости от значения хранимой переменной базы данных.Но мне сообщили, что это не очень эффективный способ выполнить то, что я хотел.Тем не менее, это позволило мне контролировать Raspberry Pi за пределами моей домашней сети.Я просто не знаю, как сделать то же самое с веб-сервером.