Как мне управлять Raspberry Pi с нелокального веб-сервера? - PullRequest
0 голосов
/ 03 мая 2019

В настоящее время у меня на сервере 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 за пределами моей домашней сети.Я просто не знаю, как сделать то же самое с веб-сервером.

...