国产精品电影_久久视频免费_欧美日韩国产激情_成年人视频免费在线播放_日本久久亚洲电影_久久都是精品_66av99_九色精品美女在线_蜜臀a∨国产成人精品_冲田杏梨av在线_欧美精品在线一区二区三区_麻豆mv在线看

SpringBoot與Californium整合,實現物聯網設備低功耗通信系統

物聯網
CoAP是一種專門為物聯網設備設計的輕量級協議,特別適用于資源受限的環境。它通過簡單的二進制消息格式、高效的傳輸機制和RESTful架構,使得在低帶寬、高延遲和不可靠網絡條件下進行通信變得容易。

CoAP是一種專門為物聯網設備設計的輕量級協議,特別適用于資源受限的環境。它通過簡單的二進制消息格式、高效的傳輸機制和RESTful架構,使得在低帶寬、高延遲和不可靠網絡條件下進行通信變得容易。

哪些公司使用Californium?

  • Intel Corporation在其 IoT 平臺和開發工具中集成 Californium 以支持 CoAP 協議。
  • IBM利用 Californium 在其 IoT 和邊緣計算解決方案中實現高效的數據傳輸。
  • 西門子使用 Californium 在其 IoT 解決方案中實現低功耗設備的通信。
  • Bosch Rexroth利用 Californium 支持其工業 IoT 應用程序中的 CoAP 通信。
  • Infineon Technologies 在其嵌入式系統和 IoT 解決方案中集成 Californium 以支持 CoAP 協議。
  • 愛立信在其 IoT 平臺中使用 Californium 實現高效的設備間通信。
  • Texas Instruments Inc.提供基于 Californium 的開發套件和示例代碼,助力開發者構建 IoT 應用。
  • ABB Ltd.在其智能制造解決方案中利用 Californium 實現高效的數據交換和控制。
  • Cisco Systems, Inc.在其 IoT 平臺上使用 Californium 實現低延遲和可靠的設備通信。

Californium的特點

  • 輕量級: 適合資源受限的設備。
  • 可靠傳輸: 支持確認消息(CON)、非確認消息(NON)和重置消息(RST)。
  • 多播支持: 允許向一組設備發送請求。
  • 觀察機制: 客戶端可以訂閱資源變化,實時接收更新。
  • 安全性: 支持DTLS(Datagram Transport Layer Security)加密。
  • RESTful架構: 使用HTTP方法(GET, POST, PUT, DELETE),便于與現有Web服務集成。

Californium的核心組件

  • CoapClient: 用于創建CoAP客戶端,發送請求并處理響應。
  • CoapServer: 用于創建CoAP服務器,處理來自客戶端的請求。
  • CoapResource: 定義CoAP資源,處理特定路徑上的請求。
  • CoapExchange: 提供請求和響應的上下文,便于處理具體業務邏輯。

代碼實操

<!-- Spring Boot Web Dependency -->
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-web</artifactId>
    </dependency>

    <!-- Californium Spring Boot Starter -->
    <dependency>
        <groupId>org.eclipse.californium</groupId>
        <artifactId>californium-spring-boot-starter-server</artifactId>
        <version>2.6.0</version>
    </dependency>

    <!-- Spring Data JPA for database operations -->
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-data-jpa</artifactId>
    </dependency>

    <!-- MySQL Driver -->
    <dependency>
        <groupId>mysql</groupId>
        <artifactId>mysql-connector-java</artifactId>
        <scope>runtime</scope>
    </dependency>

application.properties

# MySQL 數據庫配置
spring.datasource.url=jdbc:mysql://localhost:3306/iot_db?useSSL=false&serverTimezone=UTC
spring.datasource.username=root
spring.datasource.password=rootpassword
spring.datasource.driver-class-name=com.mysql.cj.jdbc.Driver

# Hibernate 配置
spring.jpa.hibernate.ddl-auto=update
spring.jpa.show-sql=true
spring.jpa.properties.hibernate.dialect=org.hibernate.dialect.MySQL8Dialect

Device實體類

package com.example.coapserver.entity;

import javax.persistence.Entity;
import javax.persistence.GeneratedValue;
import javax.persistence.GenerationType;
import javax.persistence.Id;

@Entity
publicclass Device {
    @Id
    @GeneratedValue(strategy = GenerationType.IDENTITY)
    private Long id; // 設備ID,自增主鍵
    private String deviceId; // 設備唯一標識符
    private String type; // 設備類型
    privatedouble temperature; // 溫度數據
    privateboolean active; // 設備是否激活

    // Getter 和 Setter 方法

    public Long getId() {
        return id;
    }

    public void setId(Long id) {
        this.id = id;
    }

    public String getDeviceId() {
        return deviceId;
    }

    public void setDeviceId(String deviceId) {
        this.deviceId = deviceId;
    }

    public String getType() {
        return type;
    }

    public void setType(String type) {
        this.type = type;
    }

    public double getTemperature() {
        return temperature;
    }

    public void setTemperature(double temperature) {
        this.temperature = temperature;
    }

    public boolean isActive() {
        return active;
    }

    public void setActive(boolean active) {
        this.active = active;
    }
}

倉庫接口

package com.example.coapserver.repository;

import com.example.coapserver.entity.Device;
import org.springframework.data.jpa.repository.JpaRepository;

public interface DeviceRepository extends JpaRepository<Device, Long> {
    Device findByDeviceId(String deviceId); // 根據設備ID查找設備
}

Controller

package com.example.coapserver.controller;

import com.example.coapserver.entity.Device;
import com.example.coapserver.repository.DeviceRepository;
import org.eclipse.californium.core.CoapHandler;
import org.eclipse.californium.core.CoapResponse;
import org.eclipse.californium.spring.annotation.CoapController;
import org.eclipse.californium.spring.annotation.CoapGetMapping;
import org.eclipse.californium.spring.annotation.CoapObserveRelation;
import org.eclipse.californium.spring.annotation.CoapPutMapping;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.http.HttpStatus;
import org.springframework.http.ResponseEntity;
import org.springframework.web.bind.annotation.*;

import java.util.List;
import java.util.Optional;
import java.util.concurrent.ConcurrentHashMap;
import java.util.concurrent.atomic.AtomicInteger;

@RestController
@CoapController
@RequestMapping("/api")
publicclass SensorDataController {

    privatestaticfinal Logger logger = LoggerFactory.getLogger(SensorDataController.class);

    @Autowired
    private DeviceRepository deviceRepository; // 注入設備倉庫

    // 存儲傳感器數據的并發哈希映射
    private ConcurrentHashMap<String, Double> sensorDataMap = new ConcurrentHashMap<>();
    private AtomicInteger observeCounter = new AtomicInteger(0); // 觀察計數器

    /**
     * 注冊新設備
     *
     * @param device 要注冊的設備對象
     * @return 注冊結果
     */
    @PostMapping("/register")
    public ResponseEntity<String> registerDevice(@RequestBody Device device) {
        if (deviceRepository.findByDeviceId(device.getDeviceId()) != null) {
            returnnew ResponseEntity<>("設備已注冊", HttpStatus.BAD_REQUEST);
        }
        device.setActive(true);
        deviceRepository.save(device);
        logger.info("注冊設備: {}", device.getDeviceId());
        returnnew ResponseEntity<>("設備注冊成功", HttpStatus.CREATED);
    }

    /**
     * 更新傳感器數據
     *
     * @param sensorId 傳感器ID
     * @param payload  數據負載(溫度值)
     */
    @CoapPutMapping("/sensors/{sensorId}")
    public void updateSensorData(@PathVariable String sensorId, byte[] payload) {
        String dataStr = new String(payload);
        try {
            double data = Double.parseDouble(dataStr);
            Optional<Device> deviceOpt = Optional.ofNullable(deviceRepository.findByDeviceId(sensorId));
            if (deviceOpt.isPresent()) {
                Device device = deviceOpt.get();
                device.setTemperature(data);
                deviceRepository.save(device);
                sensorDataMap.put(sensorId, data);
                logger.info("收到傳感器 {} 的數據: {}", sensorId, data);
                checkAndAlert(sensorId, data);
                observeCounter.incrementAndGet();  // 觸發觀察者通知
            } else {
                logger.warn("未知的傳感器ID: {}", sensorId);
            }
        } catch (NumberFormatException e) {
            logger.error("傳感器 {} 的數據格式無效: {}", sensorId, dataStr);
        }
    }

    /**
     * 獲取傳感器數據
     *
     * @param sensorId 傳感器ID
     * @return 傳感器數據
     */
    @CoapGetMapping("/sensors/{sensorId}")
    public String getSensorData(@PathVariable String sensorId) {
        return sensorDataMap.getOrDefault(sensorId, "無數據").toString();
    }

    /**
     * 提供一個可觀察的資源,用于實時訂閱傳感器狀態的變化
     *
     * @return 觀察計數器值
     */
    @CoapObserveRelation
    @CoapGetMapping("/observe")
    public String observeSensors() {
        int count = observeCounter.get();
        logger.info("觀察傳感器,計數器: {}", count);
        return String.valueOf(count);  // 返回計數器值以觸發觀察者通知
    }

    /**
     * 獲取所有已注冊的設備信息
     *
     * @return 設備列表
     */
    @GetMapping("/devices")
    public List<Device> getAllDevices() {
        return deviceRepository.findAll();
    }

    /**
     * 檢查溫度并觸發警報
     *
     * @param sensorId 傳感器ID
     * @param temperature 溫度值
     */
    private void checkAndAlert(String sensorId, double temperature) {
        if (temperature > 30.0) {
            logger.warn("高溫警報:傳感器 {} 的溫度為 {}°C", sensorId, temperature);
            // 在這里可以添加發送警報的通知邏輯
        }
    }
}

Application

package com.example.coapserver;

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;

@SpringBootApplication
public class CoapServerApplication {

    public static void main(String[] args) {
        SpringApplication.run(CoapServerApplication.class, args);
    }
}

測試

為了測試CoAP協議,我們可以使用Californium提供的命令行工具來發送CoAP請求。

我已經安裝Californium CLI工具。你也可以從Californium GitHub倉庫  (https://github.com/eclipse/californium)下載并編譯。很簡單的!

更新傳感器數據

cf-cli put coap://localhost:5683/api/sensors/sensor1 --payload "25.5"

輸出:

Sending PUT request to coap://localhost:5683/api/sensors/sensor1
Response from coap://localhost:5683/api/sensors/sensor1:
Code: 2.04 Changed
Payload:

獲取傳感器數據

cf-cli get coap://localhost:5683/api/sensors/sensor1

輸出:

Sending GET request to coap://localhost:5683/api/sensors/sensor1
Response from coap://localhost:5683/api/sensors/sensor1:
Code: 2.05 Content
Options: [Content-Format:text/plain]
Payload: 25.5


責任編輯:武曉燕 來源: Java知識日歷
相關推薦

2023-06-29 16:11:19

物聯網LPWA網絡

2015-11-16 14:19:50

2020-12-10 18:39:36

低功耗廣域網LPWAN物聯網

2015-10-19 11:37:04

物聯網廣域網低功耗

2018-09-11 04:31:19

低功耗廣域網LPWAN物聯網

2022-09-28 15:41:47

智能建筑物聯網

2015-09-23 11:36:06

2021-04-13 15:11:19

物聯網LoRa和BLEIoT

2019-09-17 15:25:34

WAN物聯網技術

2016-01-11 17:01:49

Wi-FiHaLow物聯網

2019-06-04 05:00:48

物聯網低功耗廣域網商業建筑

2016-03-17 09:38:58

物聯網廣域網絡

2020-03-29 23:12:34

物聯網LPWANIOT

2021-07-21 11:34:12

物聯網IOT

2024-01-16 14:53:15

物聯網IOT蜂窩漫游

2020-04-03 10:27:38

物聯網智慧城市技術

2018-10-11 05:07:19

物聯網通信IOT

2021-08-12 16:55:37

物聯網設備通信物聯網

2019-01-02 06:12:34

廣域網絡LPWAN物聯網

2023-03-08 11:30:56

點贊
收藏

51CTO技術棧公眾號

日韩久久一级片| 毛片av在线播放| 黄网站在线免费看| 精品无码三级在线观看视频| 欧美第一页在线| 成人无遮挡免费网站视频在线观看| 久久国产精品区| 韩国成人一区| 九一精品国产| 国产欧美日韩综合一区在线观看 | 最新欧美精品一区二区三区| 国外成人免费视频| 精品国产不卡| 日本精品视频在线观看| 中文日产幕无线码一区二区| 91精品国产综合久久精品| 国产美女极品在线| 色婷婷久久久综合中文字幕| 天天影院图片亚洲| 亚洲国产成人tv| 天堂影院在线| 精品久久久久一区| 岛国中文字幕在线| 91精品国产一区二区三区香蕉| 情事1991在线| 久久在线视频| 精品国产免费久久久久久尖叫| 欧美日韩影院| 粉嫩av一区二区三区天美传媒| 麻豆91在线观看| 欧美视频在线观看视频| 一色屋精品亚洲香蕉网站| 91破解版在线看| 亚洲精品在线观看网站| 黑人巨大精品欧美一区二区桃花岛| 精品视频在线播放| silk一区二区三区精品视频| 国产精品爽爽ⅴa在线观看| 韩日视频一区| 老司机午夜网站| 日韩久久一区二区| 毛片激情在线观看| 久久婷婷国产麻豆91天堂| 自拍自偷一区二区三区| 国产专区一区二区三区| 91偷拍与自偷拍精品| 波多野结衣在线| 日韩精品专区在线影院观看| 国产色噜噜噜91在线精品| 91精品国产综合久久香蕉| 国产福利精品一区二区| 欧美5-7sexvideos处| 亚洲第一免费播放区| 精品一区二区三区在线| 轻点好疼好大好爽视频| 欧美视频中文在线看| 国产精品极品在线观看| 精品在线一区| 亚洲免费观看高清在线观看| 美女的胸无遮挡在线观看| 亚洲综合色激情五月| 久久免费的精品国产v∧| 欧美三级理伦电影| 国产精品女主播| 久久久久久久精| 日本动漫同人动漫在线观看| 91九色极品视频| 国产亚洲精品超碰| 欧美aaaaaa| 加勒比成人在线| 亚洲欧美中文日韩v在线观看| 欧美日本国产| 黄色毛片在线看| 国产精品亚洲欧美导航| 中文字幕精品一区二区三区精品| 成人黄色视屏网站| a级黄色片免费| 亚洲性视频网址| 视频一区欧美日韩| 免费日本一区二区三区视频| 国产精品18毛片一区二区| 天天av天天翘天天综合网| 欧美高清视频在线观看mv| 日本二区视频| 日本精品中文字幕| 亚洲成人激情综合网| 国产成人精品免费视| 成人漫画网站免费| 亚洲xxx视频| 亚洲成色999久久网站| 国产一区二区伦理| 91麻豆精品一二三区在线| 青青草视频国产| 国外视频精品毛片| 福利视频导航一区| 麻豆精品国产传媒mv男同| 日本午夜精品久久久久| 亚洲国产成人va在线观看麻豆| 国产精品福利久久久| 欧美军同video69gay| 国产综合久久久久久鬼色| avav成人| 在线观看中文字幕| 日本成人看片网址| 欧美黑人一级爽快片淫片高清| 欧美日韩国产丝袜美女| 国产黄色91视频| 97精品国产| 丝袜诱惑一区二区| 韩国三级在线观看久| 国风产精品一区二区| 国产精品直播网红| 久久影院资源网| 欧美日韩免费高清一区色橹橹 | 美腿丝袜亚洲三区| 日韩电影在线视频| 深夜视频一区二区| 免费播放片a高清在线观看| www.夜夜爱| 日本欧美一二三区| 国产一区二区三区在线观看视频| 欧美日韩免费区域视频在线观看| 精品一区二区三区香蕉蜜桃| 91精品国偷自产在线电影 | 一本久道久久久| 国内精品久久久久久久久电影网 | 国产一区二区精品久久99| 99成人超碰| 欧美精选一区二区三区| 国产在线视频欧美一区| a毛片不卡免费看片| 欧洲视频在线免费观看| 99不卡视频| 区一区二日本| 三上悠亚在线观看| 亚洲久久中文字幕| 亚欧在线免费观看| 成人精品视频一区二区| 欧美 日韩 国产 高清| 久久久久久久久网| 一区二区精品在线观看| 视频在线99| 欧美日韩国产精品一区二区| 超碰97国产在线| 蜜桃av噜噜一区二区三| 国产综合第一页| 久久久久久国产精品一区| 日韩av大全| 中文字幕超清在线免费观看| 狠狠干视频网站| 色诱视频在线观看| 97在线资源| 97超碰人人在线| a毛片在线看免费观看| 91jq激情在线观看| 色成人免费网站| 久久午夜影院| 国产精品久久久久9999赢消| 99国产精品久久久久久久| 成人影院www在线观看| 精品午夜视频| 欧美69wwwcom| www.亚洲色图| 色综合久久久久综合99| 亚洲精品一区在线观看| 久久99精品久久久久久琪琪| 国产精品久久久久久超碰 | 日韩欧美在线免费观看视频| gogogo影视剧免费观看在线观看| 黄色片在线免费观看| 1stkiss在线漫画| 美日韩黄色大片| 久久久久久久波多野高潮日日| 久久久久久久性| 欧美性高潮在线| 国产亚洲欧美日韩一区二区| 97视频人免费观看| 国产精品麻豆免费版| 亚洲精品日韩欧美| 午夜精品123| 97超级碰碰碰久久久| 黄色成人免费看| 免费电影一区二区三区| 亚洲成av人**亚洲成av**| 国产精品男人的天堂| 国产精品一级伦理| 日本美女视频一区二区| 中文字幕精品视频| 色老板在线视频| 久久午夜精品| 欧美肥婆姓交大片| 深夜福利在线视频| 高清shemale亚洲人妖| 国产精品免费一区豆花| 波多野在线观看| 亚洲一区在线观看网站| 一本色道久久88亚洲精品综合| 蜜桃精品噜噜噜成人av| 精品一区二区三区三区| 久青青在线观看视频国产|