我有一個Node.js TCP服務器框架,它充當一箇中央TCP服務器,連接到許多傳感器收集和發送數據的TCP客戶端。這本質上是一個機器到機器的通信,TCP客戶端建立連接並開始發送數據。服務器必須認證並處理數據。如何在Node.js TCP服務器框架中識別和驗證不同的TCP客戶端(使用動態IP)?
我想幹什麼? ---> 通過識別每個客戶端並確保它們位於數據庫中的用戶列表中進行身份驗證。
我可以通過它的IP和端口識別每個入站客戶端。但是,每個客戶端都有一個動態IP。這意味着我不能依靠它來比較我的數據庫中的列表。
我的目標是確保每個連接都是有效的,並且是我的用戶數據庫的一部分。我正在考慮實現一個'應用層',傳感器(客戶端)和TCP服務器都知道它們匹配的字符串。客戶端建立連接時,會發送此字符串,服務器將使用該字符串與數據庫中的列表進行比較。這樣客戶端每次建立連接時都會發出一個「關鍵字」。
如果這是一個可行的方法,我怎麼能使用Node.js的「NET」模塊發出一個關鍵字只有在建立連接?我沒有看到任何這樣的規定。
此外,有沒有更好的方式來識別M-M連接中的客戶端?任何指針都會有幫助。
使用私鑰/公鑰認證進行安全認證。 – bolav