色哟哟视频在线观看-色哟哟视频在线-色哟哟欧美15最新在线-色哟哟免费在线观看-国产l精品国产亚洲区在线观看-国产l精品国产亚洲区久久

電子發(fā)燒友App

硬聲App

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示
創(chuàng)作
電子發(fā)燒友網(wǎng)>電子資料下載>電子資料>使用節(jié)點構(gòu)建您自己的物聯(lián)網(wǎng)平臺

使用節(jié)點構(gòu)建您自己的物聯(lián)網(wǎng)平臺

2023-06-14 | zip | 0.00 MB | 次下載 | 免費

資料介紹

描述

如果您是硬件愛好者,那么您可能已經(jīng)通過 WiFi 使 LED 閃爍。

可能在您的本地網(wǎng)絡(luò)上或使用 Blynk 或 ThingSpeak 等第三方服務(wù)通過互聯(lián)網(wǎng)。

但它要么只適用于您的本地網(wǎng)絡(luò),要么您必須使用一些第 3 方解決方案。

在本文中,我將指導(dǎo)您如何構(gòu)建您自己的 IoT 最小平臺,該平臺可在 Internet 上運行。

我們的平臺將分為三個部分,

  • 用戶界面即。前端
  • 服務(wù)器即后端
  • 硬件

應(yīng)用程序的所有三個部分都應(yīng)該能夠?qū)崟r相互通信

基于硬件的產(chǎn)品/項目的明顯協(xié)議是 MQTT。

MQTT 是一種輕量級通信協(xié)議,旨在甚至在低功耗硬件上運行。但今天我們不使用 MQTT ,為了簡單和運行服務(wù)器的成本。

像 Heroku 這樣的網(wǎng)絡(luò)托管平臺有很多,我們可以免費使用。您甚至不需要信用卡即可注冊。

MQTT 不適用于這些 PaaS(平臺即服務(wù))提供商。

所以我們將使用下一個最好的東西,Introducing Web Sockets。

它不像 MQTT 那樣簡單,但我們使用的 MCU 足夠強大來處理它。

下圖是系統(tǒng)將如何通信

pYYBAGSBsleAEiv5AAATCh_cCZQ184.png
通訊圖
?

現(xiàn)在我們已經(jīng)弄清楚了協(xié)議

我們將使用我們值得信賴的老朋友 ESP8266,它非常受歡迎,價格便宜,而且很可能您身邊就有一個 NodeMCU。

我們將使用 Arduino IDE 對我們的 ESP 進行編程

現(xiàn)在讓我們談?wù)勎覀兊姆?wù)器,我們將構(gòu)建一個 node.js [添加鏈接] 應(yīng)用程序,

我們將借助兩個 node.js 庫來創(chuàng)建我們的服務(wù)器。

用于 HTTP 連接的 express.js 和用于 WebSockets 連接的Socket.io 。

我們平臺的前端是純 HTML、CSS 和一些 JavaScript。沒有什么比 React、Angular 或 Vue 更花哨的了(但你可以期待未來的教程)。

我們的 UI 很簡單,它只有一個按鈕,我們將使用 javascript 監(jiān)聽這個按鈕的點擊并通過 WebSockets 更新服務(wù)器。

編碼時間

服務(wù)器代碼走查

讓我們從編碼我們的服務(wù)器開始。

您需要在您的機器上下載并安裝。node.js

根據(jù)操作系統(tǒng),安裝過程可能會有所不同。

完成此操作后,讓我們克隆項目代碼庫。

git clone git@github.com:B45i/ESP-Websocket-Switch.git

或者你可以從GitHub下載并解壓它(但要確保你已經(jīng)安裝git在你的機器上,我們需要它用于后面的步驟)

只想瀏覽代碼?試試這個在線代碼編輯器。

執(zhí)行此操作后,在您喜歡的代碼編輯器中打開新創(chuàng)建的文件夾,我將使用 VS Code。

你會看到這樣的東西:

pYYBAGSBslmAeRwVAABqj9ZrwyU790.png
文件夾結(jié)構(gòu)
?

固件文件夾有我們的 Arduino 代碼,該src文件夾包含我們的服務(wù)器和 UI 代碼。

package.json文件包含有關(guān)我們將需要的庫的信息,盡管它沒有安裝在我們的文件夾中。

在終端中打開我們的項目文件夾并輸入npm i (確保您的終端指向package.json文件所在的位置)

poYBAGSBslyAe5B5AABXNIonUek309.png
?

這將安裝所有必要的庫。

如果您查看 的script部分package.json,您會看到如下命令:

"scripts": {
        "dev": "nodemon src/app.js",
        "start": "node src/app.js"
}

我們可以通過鍵入npm run dev或運行這些命令npm run start

npm run dev將以開發(fā)模式運行我們的服務(wù)器,即,它將監(jiān)聽任何文件更改并重新運行服務(wù)器。

amal@Amals-MacBook-Pro esp-socket % npm run dev
> esp-socket@1.0.0 dev
> nodemon src/app.js
[nodemon] 2.0.19
[nodemon] to restart at any time, enter `rs`
[nodemon] watching path(s): *.*
[nodemon] watching extensions: js,mjs,json
[nodemon] starting `node src/app.js`
Running on :  { address: '::', family: 'IPv6', port: 4001 }

您可以通過打開應(yīng)用程序來查看http://localhost:4001/

poYBAGSBsl-ATNtQAABoXtEhrxs098.png
?

當(dāng)我們部署代碼時,服務(wù)器將使用npm run start命令運行。

這兩個命令都指向文件夾app.js中。src

我們來看看那個文件。

app.js文件是這樣開始的

import express from 'express';
import http from 'http';
import { Server } from 'socket.io';

在這里,我們將導(dǎo)入我們將要使用的所有庫。

請注意,我在這里使用 ES6 導(dǎo)入語句,在package.json文件中設(shè)置typemodule啟用此功能。

當(dāng)我們將代碼部署到像 Heroku 這樣的平臺時,我們的服務(wù)器將要運行的端口將來自一個名為PORT.

const PORT = process.env.PORT || 4001;

在本地,環(huán)境變量將為空,因此如果它為空,我們將端口設(shè)置為4001.

現(xiàn)在讓我們配置 express(node.js HTTP 框架)和Socket.io(WebSocket 庫)

const app = express();
const httpServer = http.createServer(app);
const io = new Server(httpServer, { cors: { origin: '*' } });

當(dāng)瀏覽器發(fā)送請求時,我們需要發(fā)送我們的 UI HTML / CSS 和 Javascript 文件。

這是使用 expresse 的靜態(tài)中間件完成的

app.use(express.static('src/ui'));

我們需要在服務(wù)器中維護按鈕的狀態(tài),這是使用buttonState.

let buttonState = false;

其余代碼用于管理我們的 WebSocket 連接。

io.on('connection', socket => {
	console.log('New Connection');
	io.to(socket.id).emit('buttonState', buttonState);
	.
	.
	.
}

當(dāng)新的 WS 客戶端連接到服務(wù)器時,將執(zhí)行此代碼。

在這個箭頭函數(shù)中,我們將編寫其余與 WS 相關(guān)的代碼。

WebSocket 是基于事件的,每當(dāng)你想發(fā)送一些數(shù)據(jù)時,你將它作為一個事件傳播,并附加一些信息。

當(dāng)我們查看我們的 UI 代碼時,這將更加清晰。

我們需要在客戶加入時告訴他們按鈕的當(dāng)前狀態(tài),以便他們可以同步。

io.to(socket.id).emit('buttonState', buttonState);

這段代碼獲取新加入的客戶端的 ID,并將按鈕的當(dāng)前狀態(tài)發(fā)送給它。

connection回調(diào)函數(shù)里面,可以看到各種WebSocket事件相關(guān)的代碼

socket.on('disconnect', () => {
        console.log('Disconnected');
    });

    socket.on('buttonState', value => {
				buttonState = value;
        socket.broadcast.emit('buttonState', value);
    });

第一個是disconnect當(dāng)客戶端斷開連接時的事件,這個事件被觸發(fā),我們現(xiàn)在不打算使用這個事件。

socket.on('buttonState', value => {
	 			buttonState = value;
        socket.broadcast.emit('buttonState', value);
    });

這是負(fù)責(zé)連接我們的 UI 和硬件的代碼。

當(dāng)用戶單擊 UI 上的按鈕時,我們的前端 javascript 代碼會觸發(fā)一個事件 ( buttonState)

這將執(zhí)行上面的代碼。

首先,我們將更新buttonState變量,然后獲取該值并將其發(fā)送給所有其他客戶端,除了使用它的來源socket.broadcast.emit('buttonState', value);

我們需要在指定的端口(4001在本地)上提供我們的 express 應(yīng)用程序,這段代碼正是這樣做的。

UI 代碼演練

我們的 UI 代碼駐留在src/ui文件夾中。

您將看到三個文件,index.htmlindex.js并且style.css

HTML 和 CSS 文件非常基本,它只包含按鈕和樣式。

那么讓我們看一下JS文件。

我們需要初始化socket.io對象,這是通過調(diào)用io()函數(shù)來完成的。

const socket = io();

我們需要使用 JS 獲取按鈕元素,以便我們可以為其附加事件監(jiān)聽器。

const toggleBtn = document.getElementById('toggleBtn');

我們將聲明一個名為的變量buttonState,它代表 UI 中按鈕的狀態(tài),當(dāng)用戶單擊該按鈕時,我們將翻轉(zhuǎn)該變量的值。

現(xiàn)在我們將附加一個點擊事件并監(jiān)聽這些按鈕點擊。

toggleBtn.addEventListener('click', () => {
    buttonState = !buttonState;
    updateUI();
    socket.emit('buttonState', buttonState);
});

如果它是真的,我們將否定變量值然后它變成假的。buttonState反之亦然。

然后我們調(diào)用該updateUI()函數(shù)(我們稍后會看一下這個函數(shù))

到目前為止,我們的更改是在 UI 本身上進行的,服務(wù)器并不知道它。

我們需要告訴我們的服務(wù)器關(guān)于新的更新,為此我們將使用

socket.emit('buttonState', buttonState)功能。

這將告知服務(wù)器我們 UI 的更改,服務(wù)器會將此更改廣播給其他客戶端。

當(dāng)用戶單擊按鈕時,根據(jù)狀態(tài),它的顏色和文本會發(fā)生變化。

如果按鈕關(guān)閉,那么它將是紅色的,當(dāng)它打開時它將是綠色的。

updateUI負(fù)責(zé)此更改。

const updateUI = () => {
    buttonState
        ? toggleBtn.classList.add('on')
        : toggleBtn.classList.remove('on');
    toggleBtn.innerText = buttonState ? 'Turn off' : 'Turn on';
};

如果 的值為toggleBtntrue 則我們添加一個 CSS 類,on否則我們將其刪除。這個類負(fù)責(zé)顏色。

我們還根據(jù)值更改按鈕內(nèi)的文本。

如果您npm run dev在終端中運行命令并localhost:4001在瀏覽器中打開,您應(yīng)該能夠看到我們的應(yīng)用程序 UI。

如果您在多個選項卡中打開相同的地址,您可以看到當(dāng)您單擊另一個選項卡上的按鈕時,一個選項卡中的 UI 會自動更新。

部署服務(wù)器

我們的應(yīng)用程序正在運行,但它在我們的本地機器上,我們需要部署它以便它可以在互聯(lián)網(wǎng)上的任何地方使用。

我們將使用一個名為Heroku的平臺來托管我們的應(yīng)用程序。

從 Heroku 創(chuàng)建一個免費帳戶:https ://signup.heroku.com/dc

heroku clihttps://devcenter.heroku.com/articles/heroku-cli安裝

我們將使用此命令行實用程序來管理我們的應(yīng)用程序。

通過在終端中鍵入命令,確保git和 Heroku 已成功安裝在您的計算機上。heroku

pYYBAGSBsmGARcPwAAGs9JxhQv8432.png
heroku命令的輸出'
?

現(xiàn)在 CLI 不知道您創(chuàng)建的帳戶,要連接您的 CLI 和帳戶,請heroku login在終端中鍵入,這將打開一個瀏覽器窗口,您可以從中登錄到您的 Heroku 帳戶。

heroku login
heroku: Press any key to open up the browser to login or q to exit
 ?   Warning: If browser does not open, visit
 ?   https://cli-auth.heroku.com/auth/browser/***
heroku: Waiting for login...
Logging in... done
Logged in as me@example.com

現(xiàn)在讓我們在我們的 Heroku 帳戶上創(chuàng)建一個應(yīng)用程序

heroku create

這將創(chuàng)建一個 Heroku 應(yīng)用程序,我們可以在其中托管我們的代碼。

heroku create
Creating sharp-rain-871... done, stack is heroku-18
http://sharp-rain-871.herokuapp.com/ | https://git.heroku.com/sharp-rain-871.git
Git remote heroku added

將我們的代碼部署到 Heroku 非常簡單,我們可以使用一個命令來完成。

git push heroku main

此命令執(zhí)行完畢后,我們的代碼將部署到互聯(lián)網(wǎng)上。

git push heroku main
Counting objects: 488, done.
Delta compression using up to 8 threads.
.
.
.
.
remote: Verifying deploy... done.
To https://git.heroku.com/nameless-savannah-4829.git
 * [new branch]      main -> main

為確保我們的應(yīng)用程序至少有一個實例正在運行,請運行以下命令:

heroku ps:scale web=1

要打開我們的 Web 應(yīng)用程序,請運行heroku open,這將在瀏覽器中打開我們應(yīng)用程序的 URL。

您應(yīng)該可以從互聯(lián)網(wǎng)上的任何地方打開它。

如果您從另一臺設(shè)備打開此 URL,您可以看到 UI 在您單擊另一臺設(shè)備上的按鈕時實時更新。

在兩個瀏覽器上運行的應(yīng)用程序

硬件代碼

現(xiàn)在我們將使用 Arduino IDE 對 ESP8266 微控制器進行編碼。

確保您已經(jīng)在 Arduino IDE 上安裝了ESP8266 核心和必要的庫。

該項目所需的庫:

在 Arduino IDE 上打開文件。firmware/firmware.io

您必須稍微自定義此代碼。

#define SSID "Your WiFi SSID"
#define PASSWORD "Your WiFi password"
#define SERVER "esp-socket-switch.herokuapp.com"  // Server URL (without )

SSID是您的 WiFi 名稱,PASSWORD是您的 wifi 密碼。

您需要復(fù)制鍵入時獲得的 URLheroku open并將其粘貼為SERVER.

確保URL 中沒有。

我們需要創(chuàng)建一個 SocketIOclient 類的對象

SocketIOclient socketIO;

該對象將管理我們 MCU 上的 WebSocket 連接。

現(xiàn)在讓我們看一下setup函數(shù),這里我們將連接到 WiFi,注冊輸出引腳和Socket.IO事件處理程序。

為了簡單起見,我將使用 NodeMCU 的板載 LED,如果需要,您可以連接一個外部 LED。

PS:NodeMCU 上的板載 LED 是倒置的,即當(dāng)引腳為低電平時它會亮起。
pinMode(LED_BUILTIN, OUTPUT);
Serial.begin(9600);

希望每個人都熟悉這段代碼的作用,我們將我們的引腳設(shè)置為輸出并設(shè)置串口連接的波特率。

現(xiàn)在我們將調(diào)用setupWiFi() 函數(shù),它將 MCU 連接到您指定的 WiFi SSID。

接下來的兩行與Socket.IO有關(guān)

socketIO.begin(SERVER, 80, "/socket.io/?EIO=4");
socketIO.onEvent(socketIOEvent);

在這里我們將嘗試連接到 WebSocket 服務(wù)器,并注冊Socket.IO事件處理程序。

socketIOEvent是我們的事件處理函數(shù),現(xiàn)在讓我們看一下。

void socketIOEvent(socketIOmessageType_t type, uint8_t* payload, size_t length) {
  switch (type) {
    case sIOtype_DISCONNECT:
      Serial.println("Disconnected!");
      break;

    case sIOtype_CONNECT:
      Serial.printf("Connected to url: %s%s\\n", SERVER, payload);
      socketIO.send(sIOtype_CONNECT, "/");
      break;

    case sIOtype_EVENT:
      messageHandler(payload);
      break;
  }
}

在這個函數(shù)中,你可以看到一個 switch 語句,我們現(xiàn)在甚至沒有使用連接和斷開連接。

但是對于 sIOtype_EVENT事件,我們正在調(diào)用messageHandler函數(shù),它會解析事件數(shù)據(jù)。

void messageHandler(uint8_t* payload) {
  StaticJsonDocument<64> doc;

  DeserializationError error = deserializeJson(doc, payload);

  if (error) {
    Serial.println(error.f_str());
    return;
  }

  String messageKey = doc[0];
  bool value = doc[1];

  if (messageKey == "buttonState") {
    digitalWrite(LED_BUILTIN, value);
  }
}

在此消息處理程序中,我們嘗試解析隨事件收到的 JSON 數(shù)據(jù)。

解析后的數(shù)據(jù)將在doc變量中,doc[0]將包含事件名稱并doc[1]具有值。

如果密鑰是,buttonState那么我們會將引腳狀態(tài)切換為從服務(wù)器獲得的值。

現(xiàn)在,當(dāng)我們單擊 UI 上的按鈕時,LED 應(yīng)該打開和關(guān)閉。

poYBAGSBsm2Acpi0ABqT-nSLRNQ67.jpeg
?

我希望這個小教程能幫助您學(xué)到新東西。


下載該資料的人也在下載 下載該資料的人還在閱讀
更多 >

評論

查看更多

下載排行

本周

  1. 1山景DSP芯片AP8248A2數(shù)據(jù)手冊
  2. 1.06 MB  |  532次下載  |  免費
  3. 2RK3399完整板原理圖(支持平板,盒子VR)
  4. 3.28 MB  |  339次下載  |  免費
  5. 3TC358743XBG評估板參考手冊
  6. 1.36 MB  |  330次下載  |  免費
  7. 4DFM軟件使用教程
  8. 0.84 MB  |  295次下載  |  免費
  9. 5元宇宙深度解析—未來的未來-風(fēng)口還是泡沫
  10. 6.40 MB  |  227次下載  |  免費
  11. 6迪文DGUS開發(fā)指南
  12. 31.67 MB  |  194次下載  |  免費
  13. 7元宇宙底層硬件系列報告
  14. 13.42 MB  |  182次下載  |  免費
  15. 8FP5207XR-G1中文應(yīng)用手冊
  16. 1.09 MB  |  178次下載  |  免費

本月

  1. 1OrCAD10.5下載OrCAD10.5中文版軟件
  2. 0.00 MB  |  234315次下載  |  免費
  3. 2555集成電路應(yīng)用800例(新編版)
  4. 0.00 MB  |  33566次下載  |  免費
  5. 3接口電路圖大全
  6. 未知  |  30323次下載  |  免費
  7. 4開關(guān)電源設(shè)計實例指南
  8. 未知  |  21549次下載  |  免費
  9. 5電氣工程師手冊免費下載(新編第二版pdf電子書)
  10. 0.00 MB  |  15349次下載  |  免費
  11. 6數(shù)字電路基礎(chǔ)pdf(下載)
  12. 未知  |  13750次下載  |  免費
  13. 7電子制作實例集錦 下載
  14. 未知  |  8113次下載  |  免費
  15. 8《LED驅(qū)動電路設(shè)計》 溫德爾著
  16. 0.00 MB  |  6656次下載  |  免費

總榜

  1. 1matlab軟件下載入口
  2. 未知  |  935054次下載  |  免費
  3. 2protel99se軟件下載(可英文版轉(zhuǎn)中文版)
  4. 78.1 MB  |  537798次下載  |  免費
  5. 3MATLAB 7.1 下載 (含軟件介紹)
  6. 未知  |  420027次下載  |  免費
  7. 4OrCAD10.5下載OrCAD10.5中文版軟件
  8. 0.00 MB  |  234315次下載  |  免費
  9. 5Altium DXP2002下載入口
  10. 未知  |  233046次下載  |  免費
  11. 6電路仿真軟件multisim 10.0免費下載
  12. 340992  |  191187次下載  |  免費
  13. 7十天學(xué)會AVR單片機與C語言視頻教程 下載
  14. 158M  |  183279次下載  |  免費
  15. 8proe5.0野火版下載(中文版免費下載)
  16. 未知  |  138040次下載  |  免費
主站蜘蛛池模板: 狠很橹快播 | 中文字幕在线观看亚洲视频 | 99国产在线精品观看二区 | 国产午夜一区二区三区免费视频 | 欧美性xxx免费看片 欧美性xxx极品 | 91久久偷偷看嫩草影院无费 | 99热都是精品 | 国产精品久久精品视 | 国产高清精品国语特黄A片 国产高清国内精品福利色噜噜 | 亚洲国产精品天堂在线播放 | 久久亚洲精品成人综合 | CHINA篮球体育飞机2022网站 | 德国美女密密麻麻浓毛 | 欧美另类jizzhd | 无码爽死成人777在线观看网站 | 成年人视频免费在线播放 | 麒麟色欧美影院在线播放 | 双性人皇上被c到哭 | 国产一区二区三区四区五在线观看 | 日本在线高清不卡免费播放 | 后入到高潮免费观看 | 国产日韩欧美另类 | 国产亚洲精品福利视频 | 99E久热只有精品8在线直播 | 在线涩涩免费观看国产精品 | 国产在线精品国自产拍影院午夜 | 果冻传媒 在线播放观看 | 推倒美女总裁啪啪 | 亚洲精品一卡二卡三卡四卡2021 | 国产精品人妻无码免费A片导航 | 色偷偷888欧美精品久久久 | 玖玖热视频一区二区人妻 | 国产精品国产三级国产专区53 | av天堂电影网在线观看 | 白丝萝莉喷水 | 99这里有精品视频视频 | 欧美激情精品久久久久久不卡 | 伊人久久亚洲综合天堂 | jizz老太婆| 免费国产成人高清在线观看视频 | 尤蜜网站在线进入免费 |