0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

【EsDA 应用】快速实现串口转HTTP请求

ZLG致远电子 2023-11-09 08:25 次阅读

本文将基于EsDA开发套件快速实现将串口数据转换为HTTP请求的应用开发,实现串口设备与网络服务的互联互通,提供便捷和高效的串口数据转换功能。

7b0587c0-7e96-11ee-9788-92fbcf53809c.jpg  项目简介

HTTP协议是互联网应用最为广泛的一种网络协议,由客户端发送请求消息,服务端针对客户端的请求进行响应回复。本文将基于EsDA开发平台,使用EPC6450-AWI开发板,以及图形化设计工具AWFlow Designer实现将串口数据转换为HTTP请求发送给云端,随后云端针对HTTP请求进行处理响应的功能。该项目主要用到了serial_in_ex,fscript,http_request,fileout,timer,filein和serial_out_ex节点,具体实现请见下文。

7b17f6bc-7e96-11ee-9788-92fbcf53809c.jpg  项目概述

该项目是将串口数据通过作为HTTP客户端的EPC6450-AWI开发板去发送HTTP请求到云端服务器,在云端服务器上处理HTTP请求并下发响应数据。
该项目的主要步骤如下:

  1. 配置EPC6450-AWI的网口设备并连接到互联网;
  2. 配置串口通信参数,包括波特率,数据位,停止位和校验等;
  3. 从串口读取HTTP请求参数,在本项目中串口的输入数据如下:POST方法主要是输入body消息正文,GET方法主要是输入url统一资源定位符;
  4. http_request节点向云端服务器发起HTTP请求,云端服务器处理数据后发送响应到客户端,客户端接收来自云端服务器的响应数据;
  5. HTTP客户端接收响应数据后,将响应数据中转到文本中保存并输出到串口进行显示。

7b1fe7b4-7e96-11ee-9788-92fbcf53809c.png

7b17f6bc-7e96-11ee-9788-92fbcf53809c.jpg  项目准备在本文将不再赘述串口设备在EsDA的基础通信,读者可以阅读以下文章对串口节点和EsDA的一些基础项目进行熟络:

  • 【EsDA应用】5分钟实现一个串口通信业务
  • 【EsDA应用】常用IO设备节点详解
  • EsDAMPC-ZC1应用——串口服务器(一)

1. 硬件准备

在标有丝印为TF Card 丝印的卡槽处,插入SD卡。

用户可随机选择EPC6450-AWI的可用串口设备,在本文将用UART5进行串口通信。在标有丝印为UTX5,URX5的串口模块上,将TTL转USB串口模块的TX与板子丝印为URX5连接,TTL转USB串口模块的RX与板子丝印为UTX5相连;并将TTL转USB串口模块另一端的USB口接入电脑

  • 在标有丝印为Type-C接口处,插上Type-C线,并将Type-C线的另一端USB口插入电脑。
  • 在标有丝印为NET0或 NET1的RJ45插座处接上水晶头,网线另一端水晶接头插在PC的网络插座上。

7b392a26-7e96-11ee-9788-92fbcf53809c.png

2. 网络搭建

本文的网络搭建是将电脑wifi通过以太网与开发板进行网络共享,以此达到开发板的以太网口联网的目的。

将TTL转USB串口模块接在丝印为DUART的调试串口上(TX接RX,RX接TX)。打开串口调试助手,检索并打开TTL转USB串口模块的设备端口号后,使用shell命令ip addr,查看网口的ip地址,根据下图可知,本文使用的网口设备ip地址是192.168.137.251。7b42b546-7e96-11ee-9788-92fbcf53809c.png配置PC上的以太网的IP与开发板的IP地址在同一局域网下。

7b49bba2-7e96-11ee-9788-92fbcf53809c.png

将PC上的WLAN配置共享给与开发板连接的以太网。7b519be2-7e96-11ee-9788-92fbcf53809c.png在串口调试助手输入shell指令ping www.baidu.com,ping成功即开发板联网成功。

7b5c8f34-7e96-11ee-9788-92fbcf53809c.png

7b17f6bc-7e96-11ee-9788-92fbcf53809c.jpg  项目实施本项目业务主要分为两个部分:

  • POST方法请求项目:模拟传感器数据通过串口转HTTP客户端传送到HTTP服务器,服务器进行数据分析和处理。将串口数据作为HTTP请求的body参数,http_request节点在整理属性和输入参数后对自建的HTTP服务器发起POST方法的HTTP请求;服务器收到请求后,将串口数据保存到本地的文本文件以便后续查看,下发响应数据给客户端;客户端收到服务器的响应数据经过数据处理后打印到串口助手的界面进行查看。
  • GET方法请求项目:请求访问百度服务器。串口提供HTTP请求参数,http_request节点整理属性和输入参数对百度服务器发起GET方法的HTTP请求;http_request节点接收来自百度服务器的响应数据,将数据保存到指定的文本文件中存储再从文本中将数据输出到串口助手的界面上。

1. POST方法请求

本项目由串口助手模拟将采集的传感器数据通过开发板的串口传输到开发板创建的HTTP客户端,HTTP客户端再通过POST方法将传感器数据作为body参数去请求本地搭建的HTTP服务器,HTTP服务器接收到请求后,将传感器数据存储到本地的index.html文件中,并将数据处理后作为响应体回发给客户端,HTTP客户端接收到响应消息后打印到串口助手上进行显示。

1.1 流图绘制

添加serial_in_ex,fscript,http_request,fileout,timer,filein和serial_out_ex节点到画布中并连线如下图。

7b708386-7e96-11ee-9788-92fbcf53809c.png

1.2 节点配置

在本文的serial_in_ex和serial_out_ex节点配置参数和操作一致,后面不再赘述serial_out_ex节点的配置操作。双击serial_in_ex节点,点击配置节点名旁边的铅笔图标。

7b7b9528-7e96-11ee-9788-92fbcf53809c.png

选择用户使用的串口设备,根据实际需求配置波特率,奇偶校验等串口配置参数,本项目中的串口配置参数如下图所示。7b883d5a-7e96-11ee-9788-92fbcf53809c.png

双击serial_in_ex的消费者节点fscript,因为本项目主要是将采集到的传感器数据作为消息体参数发送到HTTP服务器进行处理,所以该fscript主要是将读取到的serial_in_ex串口数据赋值给http_request节点的body参数如下:

msg.body = istream_read_string(msg.istream, 100)

双击http_request节点,配置方法为POST,并设置用户想要访问的HTTP服务器URL(这里的HTTP服务器是笔者本地用python搭建的一个简易HTTP服务器),根据需要选择输出的内容类型,其他参数按需配置即可。7b94219c-7e96-11ee-9788-92fbcf53809c.png双击http_request节点的消费者节点fscript,该节点主要是存储http_request节点的输出参数msg.payloadLength,用于后续赋值给filein节点的输入参数读取的数据长度

set(global.length, msg.payloadLength)

双击fileout节点,配置属性参数如下,在本项目中配置文件打开模式为从头写入且丢弃源文件内容,文件名选择开发板上自动挂载的/flow目录下的文件,数据来源选择payload形式。7b9f8d66-7e96-11ee-9788-92fbcf53809c.png双击timer节点,配置定时周期时长,定时用filein节点去读取存放HTTP响应的数据。7baa9fa8-7e96-11ee-9788-92fbcf53809c.png

双击timer的消费者节点fscript,配置filein节点的输入参数如下:

set(msg.topic,"exec:read_data");var length = global.lengthset(msg.payload,length);

双击filein节点,配置需要读取的文件名。7bb5d72e-7e96-11ee-9788-92fbcf53809c.png

双击filein的消费者节点fscript,该节点主要将从filein节点读取到的数据转换给serial_out_ex节点。

set(output.payload,str(msg.payload,true));

双击serial_out_ex节点,该节点配置参数与serial_in_ex节点一样。

7bc0d034-7e96-11ee-9788-92fbcf53809c.png

1.3 本地HTTP服务器搭建

笔者用python脚本搭建了一个简易的HTTP服务器,主要功能是收到的POST请求中的消息体数据存储到本地的index.html文本中,并将收到的消息体数据处理后作为响应体回发给客户端。在PC端执行以下http_server.py的脚本即开启了本地的HTTP服务端。

from http.server import BaseHTTPRequestHandler, HTTPServerimport logging
class S(BaseHTTPRequestHandler): def do_HEAD(self): self.send_response(200) self.send_header('Content-type', 'text/html') self.end_headers()
def do_POST(self): content_length = int(self.headers['Content-Length']) post_data = self.rfile.read(content_length)
logging.info("POST request,\nPath: %s\nHeaders:\n%s\n\nBody:\n%s\n", str(self.path), str(self.headers), post_data.decode('utf-8'))
res = "You Input: " + post_data.decode('utf-8') with open("index.html","a+") as f: f.write(post_data.decode('utf-8'))
self.do_HEAD() self.wfile.write("{}".format(res).encode('utf-8'))
def respond(self, opts): response = self.handle_http(opts['status'], self.path) self.wfile.write(response)
def handle_http(self, status_code, path): self.send_response(status_code) self.send_header('Content-type', 'text/html') self.end_headers() content = ''' Title goes here.

This is a test.

You accessed path: {}

'''.format(path) return bytes(content, 'UTF-8')

def run(server_class=HTTPServer, handler_class=S, port=8080): print("run()") logging.basicConfig(level=logging.INFO) server_address = ('', port) httpd = server_class(server_address, handler_class) logging.info('Starting http server...\n') try: httpd.serve_forever() except KeyboardInterrupt: pass httpd.server_close() print("httpd.server_close()") logging.info('Stopping http server...\n')

if __name__ == '__main__': from sys import argv
if len(argv) == 2: run(port=int(argv[1])) else: run()

1.4 下载运行

将流图下载到目标开发板后,在串口调试助手输入HTTP请求的消息体(模拟的传感器数据)后,就可以在串口助手输出界面看到返回的响应内容如下:7bcd2000-7e96-11ee-9788-92fbcf53809c.png本地的HTTP服务器端收到的来自客户端的请求信息如下:7bd97b84-7e96-11ee-9788-92fbcf53809c.png打开PC本地的index.html文本,可以看到保存的传感器数据如下:7be10656-7e96-11ee-9788-92fbcf53809c.png至此,串口转HTTP客户端的传感器数据上云的实验就已完全结束,接下来开启访问百度游览器的HTTP请求实验。

2. GET方法请求

该项目主要是通过GET方法请求百度服务器,最后将百度服务器响应的消息进行打印显示,主要是将串口数据转换为HTTP请求,发送到服务器端,以实现与远程服务器的通信。

2.1 流图绘制

添加serial_in_ex,fscript,http_request,fileout,timer,filein和serial_out_ex节点到画布中并连线如下图。

7be91d0a-7e96-11ee-9788-92fbcf53809c.png

2.2 节点配置

在本文的serial_in_ex和serial_out_ex节点配置参数和操作一致,后面不再赘述serial_out_ex节点的配置操作。双击serial_in_ex节点,点击配置节点名旁边的铅笔图标。

7b7b9528-7e96-11ee-9788-92fbcf53809c.png

选择用户使用的串口设备,根据实际需求配置波特率,奇偶校验等串口配置参数,本项目中的串口配置参数如下图所示。7b883d5a-7e96-11ee-9788-92fbcf53809c.png

双击serial_in_ex的消费者节点fscript,因为本项目主要是对HTTP协议的GET方法进行数据请求,而GET的请求参数是拼接在URL的后面,所以串口输入的主要是http_request节点的URL配置项,该fscript主要是读取serial_in_ex的串口数据,如下:

var str = istream_read_string(msg.istream, 100)msg.url = str

双击http_request节点,配置方法为GET,并设置用户想要访问的云端服务器URL,根据需要选择输出内容类型,其他参数按需配置即可。7c05f86c-7e96-11ee-9788-92fbcf53809c.png

双击http_request节点的消费者节点fscript,该节点主要是存储http_request节点的输出参数msg.payloadLength,用于后续赋值给filein节点的输入参数读取的数据长度

set(global.length, msg.payloadLength)

双击fileout节点,配置属性参数如下,在本项目中配置文件打开模式为从头写入且丢弃源文件内容,文件名选择开发板上自动挂载的/flow目录下的文件,数据来源选择payload形式。7b9f8d66-7e96-11ee-9788-92fbcf53809c.png双击timer节点,配置定时周期时长,定时用filein节点去读取存放HTTP响应的数据。7baa9fa8-7e96-11ee-9788-92fbcf53809c.png

双击timer的消费者节点fscript,配置filein节点的输入参数如下:

set(msg.topic,"exec:read_data");var length = global.lengthset(msg.payload,length);

双击filein节点,配置需要读取的文件名。7bb5d72e-7e96-11ee-9788-92fbcf53809c.png

双击filein的消费者节点fscript,该节点主要将从filein节点读取到的数据转换给serial_out_ex节点。

set(output.payload,str(msg.payload,true));

双击serial_out_ex节点,该节点配置参数与serial_in_ex节点一样。

7bc0d034-7e96-11ee-9788-92fbcf53809c.png

2.3 下载验证

将该流图下载到目标开发板后,在串口调试助手输入HTTP请求的云端URL后,可以看到返回的响应消息,具体如下图。7c39ba08-7e96-11ee-9788-92fbcf53809c.png至此该实验到此结束。

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • HTTP
    +关注

    关注

    0

    文章

    504

    浏览量

    31197
  • 数据转换
    +关注

    关注

    0

    文章

    87

    浏览量

    17998
  • ESDA
    +关注

    关注

    0

    文章

    28

    浏览量

    7505
收藏 人收藏

    评论

    相关推荐

    EsDA,一站式嵌入式软件

    EsDA是一套面向工业智能物联领域的嵌入式系统设计自动化工具集,包含实时操作系统AWorksLP、低代码开发平台AWStudio、资源管理平台AXPI、跨平台GUI引擎AWTK和云服务平台ZWS
    的头像 发表于 09-15 08:10 280次阅读
    <b class='flag-5'>EsDA</b>,一站式嵌入式软件

    使用NS1串口服务器HTTP模式上传服务器数据

    HTTP协议工作于客户端-服务端架构之上。浏览器作为HTTP客户端通过URL向HTTP服务端即Web服务器发送所有请求。Web服务器根据接收到的请求
    的头像 发表于 08-30 12:36 316次阅读
    使用NS1<b class='flag-5'>串口</b>服务器<b class='flag-5'>HTTP</b>模式上传服务器数据

    快速实现C2000串口程序升级

    电子发烧友网站提供《快速实现C2000串口程序升级.pdf》资料免费下载
    发表于 08-29 10:50 0次下载
    <b class='flag-5'>快速</b><b class='flag-5'>实现</b>C2000<b class='flag-5'>串口</b>程序升级

    请问如何使用HTTP请求获取本地时间?

    我正在尝试使用 AT 命令和 HTTP 请求获取本地时间,我已经从中获得了时间www.gooogle.com但这个时间是GMT时区, 我想知道如何获取本地时区,我已经尝试过 AT CIPNTP,但它不起作用。
    发表于 07-16 06:20

    USB串口串口卡的性能比较

    在当今的电子设备中,串口通信是一种非常常见的通信方式。随着技术的发展,USB接口逐渐取代了传统的串口接口,但串口通信在某些特定领域仍然具有不可替代的作用。因此,市场上出现了USB
    的头像 发表于 07-15 15:21 835次阅读

    鸿蒙开发网络管理: @ohos.net.http 数据请求

    每一个httpRequest对应一个http请求任务,不可复用
    的头像 发表于 06-18 15:42 816次阅读
    鸿蒙开发网络管理: @ohos.net.<b class='flag-5'>http</b>  数据<b class='flag-5'>请求</b>

    ESD管 AZ5825-01F型号ESDA05CPX参数对比

    ESD管 AZ5825-01F型号ESDA05CPX参数对比
    的头像 发表于 05-11 08:03 866次阅读
    <b class='flag-5'>ESD</b>管 AZ5825-01F型号<b class='flag-5'>ESDA</b>05CPX参数对比

    鸿蒙OS开发实战:【网络管理HTTP数据请求

    应用通过HTTP发起一个数据请求,支持常见的GET、POST、OPTIONS、HEAD、PUT、DELETE、TRACE、CONNECT方法。
    的头像 发表于 04-01 16:31 693次阅读
    鸿蒙OS开发实战:【网络管理<b class='flag-5'>HTTP</b>数据<b class='flag-5'>请求</b>】

    鸿蒙原生应用开发-网络管理HTTP数据请求

    一、场景介绍 应用通过HTTP发起一个数据请求,支持常见的GET、POST、OPTIONS、HEAD、PUT、DELETE、TRACE、CONNECT方法。 二、接口说明 HTTP数据请求
    发表于 03-29 17:51

    鸿蒙OS开发实例:【工具类封装-http请求

    ;@ohos.promptAction';** **封装HTTP接口请求类,提供格式化的响应信息输出功能。 使用 DevEco Studio 3.1.1 Release 及以上版本,API 版本为 api 9 及以上
    的头像 发表于 03-27 22:32 1356次阅读
    鸿蒙OS开发实例:【工具类封装-<b class='flag-5'>http</b><b class='flag-5'>请求</b>】

    arkts http 发起请求失败

    http 发起请求 官网Http
    发表于 03-23 00:33

    HTTP协议的运作方式及请求/响应的步骤

    基于HTTP的客户/服务器模式的信息交换过程它分四个过程建立连接、发送请求信息、发送响应信息、关闭连接。
    的头像 发表于 02-01 11:02 1396次阅读
    <b class='flag-5'>HTTP</b>协议的运作方式及<b class='flag-5'>请求</b>/响应的步骤

    如何利用AWFlow快速使用无线模组ZM602

    在物联网快速发展的今天,无线模组成为连接各种设备于互联网的关键组件。本文旨在介绍如何通过EsDA开发套件快速使用本公司自研的ZM602无线模组的内容。项目简介无线模组可以使设备通过无线网络
    的头像 发表于 01-26 08:25 1062次阅读
    如何利用AWFlow<b class='flag-5'>快速</b>使用无线模组ZM602

    usb串口线怎么使用 usb串口串口usb的区别

    )进行通信。因此,通过使用USB串口线,可以将现代计算机与串口设备连接起来,实现数据传输和通信。 在使用USB
    的头像 发表于 01-22 14:56 4561次阅读

    如何基于EsDA开发套件快速使用射频读卡器模块

    无线射频读写卡技术在门禁系统,电子支付领域和物联网等领域中具有越来越广泛的应用。本文将基于EsDA开发套件讲解如何快速上手并开发射频读卡器模块的相关业务,为开发者大大缩短了学习和开发时间成本。项目
    的头像 发表于 01-11 08:24 704次阅读
    如何基于<b class='flag-5'>EsDA</b>开发套件<b class='flag-5'>快速</b>使用射频读卡器模块