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

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

3天內(nèi)不再提示

物聯(lián)網(wǎng)中的DTU/RTU中的HTTP相關(guān)功能實(shí)現(xiàn)

jf_94171069 ? 來源:jf_94171069 ? 作者:jf_94171069 ? 2024-09-25 16:26 ? 次閱讀

一 概述

HTTP是一個屬于應(yīng)用層的面向?qū)ο蟮膮f(xié)議,由于其簡捷、快速的方式,適用于分布式超媒體信息系統(tǒng)。它于1990年提出,經(jīng)過幾年的使用與發(fā)展,得到不斷地完善和擴(kuò)展。目前在WWW中使用的是HTTP/1.0的第六版,HTTP/1.1的規(guī)范化工作正在進(jìn)行之中,而且HTTP-NG(Next Generation of HTTP)的建議已經(jīng)提出。

HTTP協(xié)議的主要特點(diǎn)可概括如下:

支持客戶/服務(wù)器模式。

簡單快速:客戶向服務(wù)器請求服務(wù)時,只需傳送請求方法和路徑。請求方法常用的有GET、HEAD、POST。每種方法規(guī)定了客戶與服務(wù)器聯(lián)系的類型不同。由于HTTP協(xié)議簡單,使得HTTP服務(wù)器的程序規(guī)模小,因而通信速度很快。

靈活:HTTP允許傳輸任意類型的數(shù)據(jù)對象。正在傳輸?shù)念愋陀蒀ontent-Type加以標(biāo)記。

無連接:無連接的含義是限制每次連接只處理一個請求。服務(wù)器處理完客戶的請求,并收到客戶的應(yīng)答后,即斷開連接。采用這種方式可以節(jié)省傳輸時間。

無狀態(tài):HTTP協(xié)議是無狀態(tài)協(xié)議。無狀態(tài)是指協(xié)議對于事務(wù)處理沒有記憶能力。缺少狀態(tài)意味著如果后續(xù)處理需要前面的信息,則它必須重傳,這樣可能導(dǎo)致每次連接傳送的數(shù)據(jù)量增大。另一方面,在服務(wù)器不需要先前信息時它的應(yīng)答就較快。

二 HTTP的URL

HTTP(超文本傳輸協(xié)議)是一個基于請求與響應(yīng)模式的、無狀態(tài)的、應(yīng)用層的協(xié)議,?;赥CP的連接方式,HTTP1.1版本中給出一種持續(xù)連接的機(jī)制,絕大多數(shù)的Web開發(fā),都是構(gòu)建在HTTP協(xié)議之上的Web應(yīng)用。

HTTP URL (URL是一種特殊類型的URI,包含了用于查找某個資源的足夠的信息)的格式如下: http://host[":"port][abs_path] http表示要通過HTTP協(xié)議來定位網(wǎng)絡(luò)資源;host表示合法的Internet主機(jī)域名或者IP地址;port指定一個端口號,為空則使用缺省端口80;abs_path指定請求資源的URI;如果URL中沒有給出abs_path,那么當(dāng)它作為請求URI時,必須以“/”的形式給出,通常這個工作瀏覽器自動幫我們完成。 eg: 1、輸入:www.guet.edu.cn 瀏覽器自動轉(zhuǎn)換成:http://www.guet.edu.cn/ 2、http:192.168.0.116:8080/index.jsp

二 HTTP的請求

HTTP請求由三部分組成,分別是:請求行、消息報(bào)頭、請求正文

1.請求行以一個方法符號開頭,以空格分開,后面跟著請求的URI和協(xié)議的版本,格式如下:Method Request-URI HTTP-Version CRLF

其中 Method表示請求方法;Request-URI是一個統(tǒng)一資源標(biāo)識符;HTTP-Version表示請求的HTTP協(xié)議版本;CRLF表示回車和換行(除了作為結(jié)尾的CRLF外,不允許出現(xiàn)單獨(dú)的CR或LF字符)。

請求方法(所有方法全為大寫)有多種,各個方法的解釋如下:

GET 請求獲取Request-URI所標(biāo)識的資源

POST 在Request-URI所標(biāo)識的資源后附加新的數(shù)據(jù)

HEAD 請求獲取由Request-URI所標(biāo)識的資源的響應(yīng)消息報(bào)頭

PUT 請求服務(wù)器存儲一個資源,并用Request-URI作為其標(biāo)識

DELETE 請求服務(wù)器刪除Request-URI所標(biāo)識的資源

TRACE 請求服務(wù)器回送收到的請求信息,主要用于測試或診斷

CONNECT 保留將來使用

OPTIONS 請求查詢服務(wù)器的性能,或者查詢與資源相關(guān)的選項(xiàng)和需求

應(yīng)用舉例:

GET方法:在瀏覽器的地址欄中輸入網(wǎng)址的方式訪問網(wǎng)頁時,瀏覽器采用GET方法向服務(wù)器獲取資源,eg:GET /form.html HTTP/1.1 (CRLF)

POST方法要求被請求服務(wù)器接受附在請求后面的數(shù)據(jù),常用于提交表單。

eg:POST /reg.jsp HTTP/ (CRLF)

Accept:image/gif,image/x-xbit,... (CRLF)

...

HOST:www.guet.edu.cn (CRLF)

Content-Length:22 (CRLF)

Connection:Keep-Alive (CRLF)

Cache-Control:no-cache (CRLF)

(CRLF) //該CRLF表示消息報(bào)頭已經(jīng)結(jié)束,在此之前為消息報(bào)頭

user=jeffrey&pwd=1234 //此行以下為提交的數(shù)據(jù)

HEAD方法與GET方法幾乎是一樣的,對于HEAD請求的回應(yīng)部分來說,它的HTTP頭部中包含的信息與通過GET請求所得到的信息是相同的。利用這個方法,不必傳輸整個資源內(nèi)容,就可以得到Request-URI所標(biāo)識的資源的信息。該方法常用于測試超鏈接的有效性,是否可以訪問,以及最近是否更新。

2、請求報(bào)頭后述

3、請求正文(略)

三 HTTP響應(yīng)

在接收和解釋請求消息后,服務(wù)器返回一個HTTP響應(yīng)消息。

HTTP響應(yīng)也是由三個部分組成,分別是:狀態(tài)行、消息報(bào)頭、響應(yīng)正文

1、狀態(tài)行格式如下:

HTTP-Version Status-Code Reason-Phrase CRLF

其中,HTTP-Version表示服務(wù)器HTTP協(xié)議的版本;Status-Code表示服務(wù)器發(fā)回的響應(yīng)狀態(tài)代碼;Reason-Phrase表示狀態(tài)代碼的文本描述。

狀態(tài)代碼有三位數(shù)字組成,第一個數(shù)字定義了響應(yīng)的類別,且有五種可能取值:

1xx:指示信息--表示請求已接收,繼續(xù)處理

2xx:成功--表示請求已被成功接收、理解、接受

3xx:重定向--要完成請求必須進(jìn)行更進(jìn)一步的操作

4xx:客戶端錯誤--請求有語法錯誤或請求無法實(shí)現(xiàn)

5xx:服務(wù)器端錯誤--服務(wù)器未能實(shí)現(xiàn)合法的請求

常見狀態(tài)代碼、狀態(tài)描述、說明:

200 OK //客戶端請求成功

400 Bad Request //客戶端請求有語法錯誤,不能被服務(wù)器所理解

401 Unauthorized //請求未經(jīng)授權(quán),這個狀態(tài)代碼必須和WWW-Authenticate報(bào)頭域一起使用

403 Forbidden //服務(wù)器收到請求,但是拒絕提供服務(wù)

404 Not Found //請求資源不存在,eg:輸入了錯誤的URL

500 Internal Server Error //服務(wù)器發(fā)生不可預(yù)期的錯誤

503 Server Unavailable //服務(wù)器當(dāng)前不能處理客戶端的請求,一段時間后可能恢復(fù)正常

eg:HTTP/1.1 200 OK (CRLF)

2、響應(yīng)報(bào)頭后述

3、響應(yīng)正文就是服務(wù)器返回的資源的內(nèi)容

四 HTTP組件的使用

1 Gitee鏈接地址

組件位于amaziot_bloom_os_sdklibrariesamxtuam_http.c

Gitee源碼地址:https://gitee.com/ning./hongdou

Github源碼地址:https://github.com/ayumid/hongdou

2 應(yīng)用層組件功能介紹

提供HTTP連接實(shí)例,可以通過調(diào)用組件內(nèi)的API,來實(shí)現(xiàn)HTTP本地客戶端和服務(wù)器之間的通信。

3 代碼講解

1 dtu_http_response_cb

http請求回調(diào)函數(shù)

static int dtu_http_response_cb(char *buffer, int size, int nitems, void *private_data)
{
    struct http_data_s *client_data = private_data;
    if ((client_data->data_sz + size) < sizeof(client_data-?>data)) {
        memcpy(client_data->data + client_data->data_sz, buffer, size);
        client_data->data_sz += size;
        return 0;
    }
    return -1;
}

2 dtu_http_pg_data_get

get請求實(shí)現(xiàn)

static void dtu_http_pg_data_get(DTU_MSG_UART_DATA_PARAM_T* data, UINT8 type, UINT8 channel)
{
    struct http_client *client = NULL;
    struct http_data_s *client_data = NULL;
    struct http_client_list * header = NULL;
    DTU_FILE_PARAM_T* dtu_file_ctx = NULL;
    char url[DTU_HTTP_S_URL_LEN] = {0};
    char head_tmp[DTU_HTTP_HEAD_MAX_LEN] = {0};
    UINT8* d = NULL;
    int response_code = 0;
    int i = 0;

    dtu_file_ctx = dtu_get_file_ctx();
    response_code = 0;
    d = data->UArgs;
    client_data = malloc(sizeof(*client_data));
    if (!client_data){
        return ;            
    }
    memset(client_data, 0, sizeof(*client_data));
    
    client = http_client_init();
    if (!client){
        free(client_data);
        client_data = NULL;
        return ;
    }

    d[data->len] = '';
    if(1 == channel)
    {
        if(NULL == memchr(dtu_file_ctx->http.http1.url, '?', strlen(dtu_file_ctx->http.http1.url)))
        {
            snprintf(url, DTU_HTTP_S_URL_LEN, "%s?data=%s", dtu_file_ctx->http.http1.url, (char*)data->UArgs);
        }
        else
        {
            snprintf(url, DTU_HTTP_S_URL_LEN, "%s&data=%s", dtu_file_ctx->http.http1.url, (char*)data->UArgs);
        }
        http_client_setopt(client, HTTPCLIENT_OPT_URL, url);
    }
    else if(2 == channel)
    {
        if(NULL == memchr(dtu_file_ctx->http.http1.url, '?', strlen(dtu_file_ctx->http.http1.url)))
        {
            snprintf(url, DTU_HTTP_S_URL_LEN, "%s?data=%s", dtu_file_ctx->http.http2.url, (char*)data->UArgs);
        }
        else
        {
            snprintf(url, DTU_HTTP_S_URL_LEN, "%s&data=%s", dtu_file_ctx->http.http2.url, (char*)data->UArgs);
        }
        http_client_setopt(client, HTTPCLIENT_OPT_URL, url);
    }
    uprintf("http get url: %s", url);
    http_client_setopt(client, HTTPCLIENT_OPT_RESPONSECB, dtu_http_response_cb);
    http_client_setopt(client, HTTPCLIENT_OPT_RESPONSECB_DATA, client_data);
    http_client_setopt(client, HTTPCLIENT_OPT_METHOD, HTTPCLIENT_REQUEST_GET);
    // Add private HTTP header
    if(1 == channel)
    {
        if(strlen(dtu_file_ctx->http.http1.head1))
        {
            snprintf(head_tmp, DTU_HTTP_HEAD_MAX_LEN, "%srn", dtu_file_ctx->http.http1.head1);
            header = http_client_list_append(header, head_tmp);
            uprintf("head11: %s", head_tmp);
        }
        if(strlen(dtu_file_ctx->http.http1.head2))
        {
            snprintf(head_tmp, DTU_HTTP_HEAD_MAX_LEN, "%srn", dtu_file_ctx->http.http1.head2);
            header = http_client_list_append(header, head_tmp);
            uprintf("head12: %s", head_tmp);
        }
        if(strlen(dtu_file_ctx->http.http1.head3))
        {
            snprintf(head_tmp, DTU_HTTP_HEAD_MAX_LEN, "%srn", dtu_file_ctx->http.http1.head3);
            header = http_client_list_append(header, head_tmp);
            uprintf("head13: %s", head_tmp);
        }
    }
    else if(2 == channel)
    {
        if(strlen(dtu_file_ctx->http.http2.head1))
        {
            snprintf(head_tmp, DTU_HTTP_HEAD_MAX_LEN, "%srn", dtu_file_ctx->http.http2.head1);
            header = http_client_list_append(header, head_tmp);
            uprintf("head21: %s", head_tmp);
        }
        if(strlen(dtu_file_ctx->http.http2.head2))
        {
            snprintf(head_tmp, DTU_HTTP_HEAD_MAX_LEN, "%srn", dtu_file_ctx->http.http2.head2);
            header = http_client_list_append(header, head_tmp);
            uprintf("head22: %s", head_tmp);
        }
        if(strlen(dtu_file_ctx->http.http2.head3))
        {
            snprintf(head_tmp, DTU_HTTP_HEAD_MAX_LEN, "%srn", dtu_file_ctx->http.http2.head3);
            header = http_client_list_append(header, head_tmp);
            uprintf("head23: %s", head_tmp);
        }
    }
    
    http_client_setopt(client, HTTPCLIENT_OPT_HTTPHEADER, header);

    http_client_perform(client);
    http_client_getinfo(client, HTTPCLIENT_GETINFO_RESPONSE_CODE, &response_code);
    uprintf("[http get]Get tcp state %dn", response_code);

    if (response_code >= 200 && response_code < 300)
    {
        if(client_data-?>data_sz)
        {
            uprintf("rn data_sz=%u, %s", client_data->data_sz,client_data->data);
            for (i = 0; i < 100; i++)
            {
                //uprintf("%02x ",client_data-?>data[i]);
            }
        }
    }else if (response_code == 404) {
        uprintf("response_code == %drn%s",response_code ,client_data->data);
    }

    if (client_data)
    {
        free(client_data);
        client_data = NULL;
    }
        
    if (client)
    {
        http_client_shutdown(client);
        client = NULL;
    }

}

3 dtu_http_pg_data_post

post請求實(shí)現(xiàn)

static void dtu_http_pg_data_post(DTU_MSG_UART_DATA_PARAM_T* data, UINT8 type, UINT8 channel)
{
    struct http_client *client = NULL;
    struct http_data_s *client_data = NULL;
    struct http_client_list * header = NULL;
    DTU_FILE_PARAM_T* dtu_file_ctx = NULL;
    char head_tmp[DTU_HTTP_HEAD_MAX_LEN] = {0};
    UINT8* d = NULL;
    int response_code = 0;
    int i = 0;
    
    dtu_file_ctx = dtu_get_file_ctx();
    response_code = 0;
    d = data->UArgs;
    
    client_data = malloc(sizeof(*client_data));
    if (!client_data){
        return ;            
    }
    memset(client_data, 0, sizeof(*client_data));
    
    client = http_client_init();
    if (!client){
        free(client_data);
        client_data = NULL;
        return ;
    }

    if(1 == channel)
    {
        http_client_setopt(client, HTTPCLIENT_OPT_URL, dtu_file_ctx->http.http1.url);
    }
    else if(2 == channel)
    {
        http_client_setopt(client, HTTPCLIENT_OPT_URL, dtu_file_ctx->http.http2.url);
    }
    http_client_setopt(client, HTTPCLIENT_OPT_RESPONSECB, dtu_http_response_cb);
    http_client_setopt(client, HTTPCLIENT_OPT_RESPONSECB_DATA, client_data);
    http_client_setopt(client, HTTPCLIENT_OPT_METHOD, HTTPCLIENT_REQUEST_POST);
//    // Add private HTTP header
    if(1 == channel)
    {
        if(strlen(dtu_file_ctx->http.http1.head1))
        {
            snprintf(head_tmp, DTU_HTTP_HEAD_MAX_LEN, "%srn", dtu_file_ctx->http.http1.head1);
            header = http_client_list_append(header, head_tmp);
            uprintf("head11: %s", head_tmp);
        }
        if(strlen(dtu_file_ctx->http.http1.head2))
        {
            snprintf(head_tmp, DTU_HTTP_HEAD_MAX_LEN, "%srn", dtu_file_ctx->http.http1.head2);
            header = http_client_list_append(header, head_tmp);
            uprintf("head12: %s", head_tmp);
        }
        if(strlen(dtu_file_ctx->http.http1.head3))
        {
            snprintf(head_tmp, DTU_HTTP_HEAD_MAX_LEN, "%srn", dtu_file_ctx->http.http1.head3);
            header = http_client_list_append(header, head_tmp);
            uprintf("head13: %s", head_tmp);
        }
    }
    else if(2 == channel)
    {
        if(strlen(dtu_file_ctx->http.http2.head1))
        {
            snprintf(head_tmp, DTU_HTTP_HEAD_MAX_LEN, "%srn", dtu_file_ctx->http.http2.head1);
            header = http_client_list_append(header, head_tmp);
            uprintf("head21: %s", head_tmp);
        }
        if(strlen(dtu_file_ctx->http.http2.head2))
        {
            snprintf(head_tmp, DTU_HTTP_HEAD_MAX_LEN, "%srn", dtu_file_ctx->http.http2.head2);
            header = http_client_list_append(header, head_tmp);
            uprintf("head22: %s", head_tmp);
        }
        if(strlen(dtu_file_ctx->http.http2.head3))
        {
            snprintf(head_tmp, DTU_HTTP_HEAD_MAX_LEN, "%srn", dtu_file_ctx->http.http2.head3);
            header = http_client_list_append(header, head_tmp);
            uprintf("head23: %s", head_tmp);
        }
    }
    d[data->len] = '';
    http_client_setopt(client, HTTPCLIENT_OPT_HTTPHEADER, header);
    http_client_setopt(client, HTTPCLIENT_OPT_POSTDATA, data->UArgs); /*post data is http context*/
    http_client_setopt(client, HTTPCLIENT_OPT_POSTLENGTH, strlen(data->UArgs));    /*http context length*/      
    http_client_perform(client);
    http_client_getinfo(client, HTTPCLIENT_GETINFO_RESPONSE_CODE, &response_code);
    uprintf("[http post]Get tcp state %dn", response_code);

    if (response_code >= 200 && response_code < 300)
    {
         if(client_data-?>data_sz)
         {
            uprintf("rn data_sz=%u, %s", client_data->data_sz,client_data->data);                
            for (i = 0; i < 100; i++)
            {
                //uprintf("%02x ",client_data-?>data[i]);
            }
         }
    }else if (response_code == 404) {
        uprintf("response_code == %drn%s",response_code ,client_data->data);
    }
    
    if (client_data)
    {
        free(client_data);
        client_data = NULL;
    }
        
    if (client)
    {
        http_client_shutdown(client);
        client = NULL;
    }

}

4 Demo實(shí)戰(zhàn)

參考進(jìn)階實(shí)戰(zhàn)

本文章源自奇跡物聯(lián)開源的物聯(lián)網(wǎng)應(yīng)用知識庫Cellular IoT Wiki,更多技術(shù)干貨歡迎關(guān)注收藏Wiki:Cellular IoT Wiki 知識庫(https://rckrv97mzx.feishu.cn/wiki/wikcnBvAC9WOkEYG5CLqGwm6PHf)

歡迎同學(xué)們走進(jìn)AmazIOT知識庫的世界!

這里是為物聯(lián)網(wǎng)人構(gòu)建的技術(shù)應(yīng)用百科,以便幫助你更快更簡單的開發(fā)物聯(lián)網(wǎng)產(chǎn)品

Cellular IoT Wiki初心:

在我們長期投身于蜂窩物聯(lián)網(wǎng) ODM/OEM 解決方案的實(shí)踐過程中,一直被物聯(lián)網(wǎng)技術(shù)碎片化與產(chǎn)業(yè)資源碎片化的問題所困擾。從產(chǎn)品定義、芯片選型,到軟硬件研發(fā)和測試,物聯(lián)網(wǎng)技術(shù)的碎片化以及產(chǎn)業(yè)資源的碎片化,始終對團(tuán)隊(duì)的產(chǎn)品開發(fā)交付質(zhì)量和效率形成制約。為了減少因物聯(lián)網(wǎng)碎片化而帶來的重復(fù)開發(fā)工作,我們著手對物聯(lián)網(wǎng)開發(fā)中高頻應(yīng)用的技術(shù)知識進(jìn)行沉淀管理,并基于 Bloom OS 搭建了不同平臺的 RTOS 應(yīng)用生態(tài)。后來我們發(fā)現(xiàn),很多物聯(lián)網(wǎng)產(chǎn)品開發(fā)團(tuán)隊(duì)都面臨著相似的困擾,于是,我們決定向全體物聯(lián)網(wǎng)行業(yè)開發(fā)者開放奇跡物聯(lián)內(nèi)部沉淀的應(yīng)用技術(shù)知識庫 Wiki,期望能為更多物聯(lián)網(wǎng)產(chǎn)品開發(fā)者減輕一些重復(fù)造輪子的負(fù)擔(dān)。

Cellular IoT Wiki沉淀的技術(shù)內(nèi)容方向如下:

wKgaombqoM2AYL2RAAQrZ8e-uz8392.jpg

奇跡物聯(lián)的業(yè)務(wù)服務(wù)范圍:基于自研的NB-IoT、Cat1、Cat4等物聯(lián)網(wǎng)模組,為客戶物聯(lián)網(wǎng)ODM/OEM解決方案服務(wù)。我們的研發(fā)技術(shù)中心在石家莊,PCBA生產(chǎn)基地分布在深圳、石家莊、北京三個工廠,滿足不同區(qū)域&不同量產(chǎn)規(guī)模&不同產(chǎn)品開發(fā)階段的生產(chǎn)制造任務(wù)。跟傳統(tǒng)PCBA工廠最大的區(qū)別是我們只服務(wù)物聯(lián)網(wǎng)行業(yè)客戶。

連接我們,和10000+物聯(lián)網(wǎng)開發(fā)者一起 降低技術(shù)和成本門檻

讓蜂窩物聯(lián)網(wǎng)應(yīng)用更簡單~~

哈哈你終于滑到最重要的模塊了,

千萬不!要!劃!走!忍住沖動!~

歡迎加入飛書“開源技術(shù)交流”,隨時找到我們哦~

點(diǎn)擊鏈接如何加入奇跡物聯(lián)技術(shù)話題群(https://rckrv97mzx.feishu.cn/docx/Xskpd1cFQo7hu9x5EuicbsjTnTf)可以獲取加入技術(shù)話題群攻略

Hey 物聯(lián)網(wǎng)從業(yè)者,

你是否有了解過奇跡物聯(lián)的官方公眾號“eSIM物聯(lián)工場”呢?

這里是奇跡物聯(lián)的物聯(lián)網(wǎng)應(yīng)用技術(shù)開源wiki主陣地,歡迎關(guān)注公眾號,不迷路~

及時獲得最新物聯(lián)網(wǎng)應(yīng)用技術(shù)沉淀發(fā)布

(如有侵權(quán),聯(lián)系刪除)

審核編輯 黃宇

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報(bào)投訴
  • 物聯(lián)網(wǎng)
    +關(guān)注

    關(guān)注

    2895

    文章

    43498

    瀏覽量

    366937
  • HTTP
    +關(guān)注

    關(guān)注

    0

    文章

    484

    瀏覽量

    30791
收藏 人收藏

    評論

    相關(guān)推薦

    TLINK聯(lián)網(wǎng)輕松實(shí)現(xiàn)MODBUS RTU通訊連接

    DTU+PLCPLC串口使用MODBUS RTU協(xié)議,比如說我用03功能碼去讀取PLC的8個寄存器:請求指令:01 03 00 00 00 08 44 0C應(yīng)答指令:01 03 10 4E 1F 4E 1F 4E
    發(fā)表于 07-09 19:22

    DTURTU的區(qū)別大盤點(diǎn)

    `  無線通信網(wǎng)絡(luò)行業(yè)往往出現(xiàn)兩個產(chǎn)品,DTURTU,那么DTU是什么?RTU又是什么,DTU
    發(fā)表于 03-01 17:47

    聯(lián)網(wǎng)卡與智能音響具體實(shí)現(xiàn)了哪些功能?-聯(lián)網(wǎng)

    `聯(lián)網(wǎng)卡與智能音響具體實(shí)現(xiàn)了哪些功能?現(xiàn)在科技技術(shù)一天天的在進(jìn)步,智能產(chǎn)品也越來越多了,但是最吸引人的還是智能產(chǎn)品的交互功能。智能音箱是音
    發(fā)表于 06-01 16:44

    RTURTU設(shè)備/GPRS RTU)產(chǎn)品如何選型

    聯(lián)網(wǎng)智能終端(RTUDTU)是基于GPRS、CDMA 、3G/4G、NB-IoT、LoRa等通信網(wǎng)絡(luò)實(shí)現(xiàn)遠(yuǎn)程數(shù)據(jù)采集、處理、存儲、加密
    發(fā)表于 11-10 11:03

    RTUDTU有哪些區(qū)別?

    RTUDTU都是聯(lián)網(wǎng)通信終端設(shè)備,二者各有何功能特點(diǎn)呢?
    發(fā)表于 11-28 08:51

    聯(lián)網(wǎng)無線傳輸模塊基本功能

    ,廣泛應(yīng)用于狀態(tài)感知、設(shè)施監(jiān)測、數(shù)據(jù)交互、運(yùn)行控制等各種聯(lián)網(wǎng)應(yīng)用場景?;?b class='flag-5'>功能:數(shù)據(jù)采集:采集傳感器、計(jì)量儀表、PLC等輸出數(shù)據(jù)或信號。狀態(tài)監(jiān)測:監(jiān)測各類設(shè)備的供電狀態(tài)、啟/停狀態(tài)
    發(fā)表于 06-25 04:20

    工業(yè)聯(lián)網(wǎng)RTUDTU的區(qū)別在哪

    RTUDTU1. RTU1.1 簡介1.2 構(gòu)成1.3 特點(diǎn)1.4 應(yīng)用2. DTU2.1 簡介2.2 構(gòu)成2.3 特點(diǎn)2.4 應(yīng)用3. RTU
    發(fā)表于 07-21 08:25

    dtu,rtu,ttu,ftu的區(qū)別

    dtu,rtu,ttu,ftu的區(qū)別,DTU是Data Transfer unit的縮寫,中文名稱是數(shù)據(jù)傳輸單元,用于在遠(yuǎn)端將PLC等下位機(jī)設(shè)備的數(shù)據(jù)透傳到服務(wù)器上,專門用于將串口數(shù)據(jù)轉(zhuǎn)換為IP數(shù)據(jù)
    發(fā)表于 07-21 07:03

    基于機(jī)智云聯(lián)網(wǎng)平臺與4G DTU遠(yuǎn)程車庫門

    快速接入機(jī)智云聯(lián)網(wǎng)平臺,以及論述如何在機(jī)智云的新版開發(fā)者中心對DTU進(jìn)行Modbus RTU協(xié)議的配置。借助成熟的LTE網(wǎng)絡(luò)以廣覆蓋、高速率、低延時、超高性價比的優(yōu)勢,為中低速率
    發(fā)表于 08-03 16:44

    請問DTURTU有什么區(qū)別?

    DTURTU有什么區(qū)別?
    發(fā)表于 06-27 06:38

    DTURTU有什么區(qū)別

    DTURTU聯(lián)網(wǎng)通信行業(yè)中經(jīng)常使用到的兩類產(chǎn)品,那么DTU是什么,RTU又是什么呢?
    的頭像 發(fā)表于 09-17 20:12 ?1.9w次閱讀

    聯(lián)網(wǎng)應(yīng)用,為什么MQTT干掉了HTTP?

    HTTP作為當(dāng)下使用最為廣泛的協(xié)議之一,但隨著聯(lián)網(wǎng)行業(yè)的發(fā)展,MQTT在過去的幾年也受到了大量聯(lián)網(wǎng)開發(fā)人員的青睞。下面我們就分別對
    的頭像 發(fā)表于 04-27 09:33 ?613次閱讀
    <b class='flag-5'>物</b><b class='flag-5'>聯(lián)網(wǎng)</b>應(yīng)用<b class='flag-5'>中</b>,為什么MQTT干掉了<b class='flag-5'>HTTP</b>?

    全網(wǎng)通DTU聯(lián)網(wǎng)關(guān)有哪些區(qū)別呢?

    全網(wǎng)通DTU聯(lián)網(wǎng)關(guān)有哪些區(qū)別呢? 全網(wǎng)通DTU(Data Transfer Unit)和聯(lián)網(wǎng)
    的頭像 發(fā)表于 12-15 10:10 ?1002次閱讀

    從邊緣到云端,合宙DTU&amp;amp;RTU打造無縫聯(lián)網(wǎng)解決方案

    DTU(數(shù)據(jù)傳輸單元)與RTU(遠(yuǎn)程終端單元)是連接邊緣與云端的橋梁,是實(shí)現(xiàn)數(shù)據(jù)無縫流動的關(guān)鍵。 合宙推出的 DTU&RTU成功推動了眾多
    的頭像 發(fā)表于 09-12 15:27 ?797次閱讀
    從邊緣到云端,合宙<b class='flag-5'>DTU</b>&amp;amp;<b class='flag-5'>RTU</b>打造無縫<b class='flag-5'>物</b><b class='flag-5'>聯(lián)網(wǎng)</b>解決方案

    從邊緣設(shè)備到云端平臺,合宙DTU&amp;RTU打造無縫聯(lián)網(wǎng)解決方案

    ? 如今,聯(lián)網(wǎng)(IoT)技術(shù)飛速發(fā)展,萬互聯(lián)的時代已然到來,那么,高效、穩(wěn)定地連接邊緣設(shè)備與云端平臺,實(shí)現(xiàn)數(shù)據(jù)的實(shí)時采集、傳輸與處理,就成為了推動物
    的頭像 發(fā)表于 09-18 14:55 ?170次閱讀
    從邊緣設(shè)備到云端平臺,合宙<b class='flag-5'>DTU</b>&amp;<b class='flag-5'>RTU</b>打造無縫<b class='flag-5'>物</b><b class='flag-5'>聯(lián)網(wǎng)</b>解決方案