【EsDA 应用】快速实现串口转HTTP请求
off999 2024-10-27 11:54 27 浏览 0 评论
1、项目简介
HTTP协议是互联网应用最为广泛的一种网络协议,由客户端发送请求消息,服务端针对客户端的请求进行响应回复。本文将基于EsDA开发平台,使用EPC6450-AWI开发板,以及图形化设计工具AWFlow Designer实现将串口数据转换为HTTP请求发送给云端,随后云端针对HTTP请求进行处理响应的功能。该项目主要用到了serial_in_ex,fscript,http_request,fileout,timer,filein和serial_out_ex节点,具体实现请见下文。
2、项目概述
该项目是将串口数据通过作为HTTP客户端的EPC6450-AWI开发板去发送HTTP请求到云端服务器,在云端服务器上处理HTTP请求并下发响应数据。
该项目的主要步骤如下:
1、配置EPC6450-AWI的网口设备并连接到互联网
2、配置串口通信参数,包括波特率,数据位,停止位和校验等
3、从串口读取HTTP请求参数,在本项目中串口的输入数据如下:POST方法主要是输入body消息正文,GET方法主要是输入url统一资源定位符
4、http_request节点向云端服务器发起HTTP请求,云端服务器处理数据后发送响应到客户端,客户端接收来自云端服务器的响应数据
5、HTTP客户端接收响应数据后,将响应数据中转到文本中保存并输出到串口进行显示
3、项目准备
在本文将不再赘述串口设备在EsDA的基础通信,读者可以阅读以下文章对串口节点和EsDA的一些基础项目进行熟络:
【EsDA应用】5分钟实现一个串口通信业务
【EsDA 应用】常用IO设备节点详解
EsDA MPC-ZC1应用——串口服务器(一)
3.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的网络插座上
3.2、网络搭建
本文的网络搭建是将电脑wifi通过以太网与开发板进行网络共享,以此达到开发板的以太网口联网的目的
将TTL转USB串口模块接在丝印为DUART的调试串口上(TX接RX,RX接TX)
打开串口调试助手,检索并打开TTL转USB串口模块的设备端口号后,使用shell命令ip addr,查看网口的ip地址,根据下图可知,本文使用的网口设备ip地址是192.168.137.251
配置PC上的以太网的IP与开发板的IP地址在同一局域网下
将PC上的WLAN配置共享给与开发板连接的以太网
在串口调试助手输入shell指令ping www.baidu.com,ping成功即开发板联网成功
4、项目实施
本项目业务主要分为两个部分:
POST方法请求项目:模拟传感器数据通过串口转HTTP客户端传送到HTTP服务器,服务器进行数据分析和处理。将串口数据作为HTTP请求的body参数,http_request节点在整理属性和输入参数后对自建的HTTP服务器发起POST方法的HTTP请求;服务器收到请求后,将串口数据保存到本地的文本文件以便后续查看,下发响应数据给客户端;客户端收到服务器的响应数据经过数据处理后打印到串口助手的界面进行查看。
GET方法请求项目:请求访问百度服务器。串口提供HTTP请求参数,http_request节点整理属性和输入参数对百度服务器发起GET方法的HTTP请求;http_request节点接收来自百度服务器的响应数据,将数据保存到指定的文本文件中存储再从文本中将数据输出到串口助手的界面上。
4.1、POST方法请求
本项目由串口助手模拟将采集的传感器数据通过开发板的串口传输到开发板创建的HTTP客户端,HTTP客户端再通过POST方法将传感器数据作为body参数去请求本地搭建的HTTP服务器,HTTP服务器接收到请求后,将传感器数据存储到本地的index.html文件中,并将数据处理后作为响应体回发给客户端,HTTP客户端接收到响应消息后打印到串口助手上进行显示。
4.1.1、流图绘制
添加serial_in_ex,fscript,http_request,fileout,timer,filein和serial_out_ex节点到画布中并连线如下图。
4.1.2、节点配置
在本文的serial_in_ex和serial_out_ex节点配置参数和操作一致,后面不再赘述serial_out_ex节点的配置操作。双击serial_in_ex节点,点击配置节点名旁边的铅笔图标。
选择用户使用的串口设备,根据实际需求配置波特率,奇偶校验等串口配置参数,本项目中的串口配置参数如下图所示。
双击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服务器),根据需要选择输出的内容类型,其他参数按需配置即可。
双击http_request节点的消费者节点fscript,该节点主要是存储http_request节点的输出参数msg.payloadLength,用于后续赋值给filein节点的输入参数读取的数据长度。
set(global.length, msg.payloadLength)
双击fileout节点,配置属性参数如下,在本项目中配置文件打开模式为从头写入且丢弃源文件内容,文件名选择开发板上自动挂载的/flow目录下的文件,数据来源选择payload形式。
双击timer节点,配置定时周期时长,定时用filein节点去读取存放HTTP响应的数据
双击timer的消费者节点fscript,配置filein节点的输入参数如下
set(msg.topic,"exec:read_data");var length = global.lengthset(msg.payload,length);
双击filein节点,配置需要读取的文件名
双击filein的消费者节点fscript,该节点主要将从filein节点读取到的数据转换给serial_out_ex节点
set(output.payload,str(msg.payload,true));
双击serial_out_ex节点,该节点配置参数与serial_in_ex节点一样
4.1.3、本地HTTP服务器搭建
笔者用python脚本搭建了一个简易的HTTP服务器,主要功能是收到的POST请求中的消息体数据存储到本地的index.html文本中,并将收到的消息体数据处理后作为响应体回发给客户端。在PC端执行以下http_server.py的脚本即开启了本地的HTTP服务端。
from http.server import BaseHTTPRequestHandler, HTTPServerimport loggingclass 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 = ''' <html><head><title>Title goes here.</title></head> <body><p>This is a test.</p> <p>You accessed path: {}</p> </body></html> '''.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()
4.1.4、下载运行
将流图下载到目标开发板后,在串口调试助手输入HTTP请求的消息体(模拟的传感器数据)后,就可以在串口助手输出界面看到返回的响应内容如下:
本地的HTTP服务器端收到的来自客户端的请求信息如下:
打开PC本地的index.html文本,可以看到保存的传感器数据如下:
至此,串口转HTTP客户端的传感器数据上云的实验就已完全结束,接下来开启访问百度游览器的HTTP请求实验。
4.2、GET方法请求
该项目主要是通过GET方法请求百度服务器,最后将百度服务器响应的消息进行打印显示,主要是将串口数据转换为HTTP请求,发送到服务器端,以实现与远程服务器的通信。
4.2.1、流图绘制
添加serial_in_ex,fscript,http_request,fileout,timer,filein和serial_out_ex节点到画布中并连线如下图。
4.2.2、节点配置
在本文的serial_in_ex和serial_out_ex节点配置参数和操作一致,后面不再赘述serial_out_ex节点的配置操作。双击serial_in_ex节点,点击配置节点名旁边的铅笔图标。
选择用户使用的串口设备,根据实际需求配置波特率,奇偶校验等串口配置参数,本项目中的串口配置参数如下图所示。
双击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,根据需要选择输出内容类型,其他参数按需配置即可。
双击http_request节点的消费者节点fscript,该节点主要是存储http_request节点的输出参数msg.payloadLength,用于后续赋值给filein节点的输入参数读取的数据长度。
set(global.length, msg.payloadLength)
双击fileout节点,配置属性参数如下,在本项目中配置文件打开模式为从头写入且丢弃源文件内容,文件名选择开发板上自动挂载的/flow目录下的文件,数据来源选择payload形式。
双击timer节点,配置定时周期时长,定时用filein节点去读取存放HTTP响应的数据
双击timer的消费者节点fscript,配置filein节点的输入参数如下
set(msg.topic,"exec:read_data");var length = global.lengthset(msg.payload,length);
双击filein节点,配置需要读取的文件名
双击filein的消费者节点fscript,该节点主要将从filein节点读取到的数据转换给serial_out_ex节点
set(output.payload,str(msg.payload,true));
双击serial_out_ex节点,该节点配置参数与serial_in_ex节点一样
4.2.3、下载验证
将该流图下载到目标开发板后,在串口调试助手输入HTTP请求的云端URL后,可以看到返回的响应消息体如下。至此该实验到此结束。
相关推荐
- 阿里云国际站ECS:阿里云ECS如何提高网站的访问速度?
-
TG:@yunlaoda360引言:速度即体验,速度即业务在当今数字化的世界中,网站的访问速度已成为决定用户体验、用户留存乃至业务转化率的关键因素。页面加载每延迟一秒,都可能导致用户流失和收入损失。对...
- 高流量大并发Linux TCP性能调优_linux 高并发网络编程
-
其实主要是手里面的跑openvpn服务器。因为并没有明文禁p2p(哎……想想那么多流量好像不跑点p2p也跑不完),所以造成有的时候如果有比较多人跑BT的话,会造成VPN速度急剧下降。本文所面对的情况为...
- 性能测试100集(12)性能指标资源使用率
-
在性能测试中,资源使用率是评估系统硬件效率的关键指标,主要包括以下四类:#性能测试##性能压测策略##软件测试#1.CPU使用率定义:CPU处理任务的时间占比,计算公式为1-空闲时间/总...
- Linux 服务器常见的性能调优_linux高性能服务端编程
-
一、Linux服务器性能调优第一步——先搞懂“看什么”很多人刚接触Linux性能调优时,总想着直接改配置,其实第一步该是“看清楚问题”。就像医生看病要先听诊,调优前得先知道服务器“哪里...
- Nginx性能优化实战:手把手教你提升10倍性能!
-
关注△mikechen△,十余年BAT架构经验倾囊相授!Nginx是大型架构而核心,下面我重点详解Nginx性能@mikechen文章来源:mikechen.cc1.worker_processe...
- 高并发场景下,Spring Cloud Gateway如何抗住百万QPS?
-
关注△mikechen△,十余年BAT架构经验倾囊相授!大家好,我是mikechen。高并发场景下网关作为流量的入口非常重要,下面我重点详解SpringCloudGateway如何抗住百万性能@m...
- Kubernetes 高并发处理实战(可落地案例 + 源码)
-
目标场景:对外提供HTTPAPI的微服务在短时间内收到大量请求(例如每秒数千至数万RPS),要求系统可弹性扩容、限流降级、缓存减压、稳定运行并能自动恢复。总体思路(多层防护):边缘层:云LB...
- 高并发场景下,Nginx如何扛住千万级请求?
-
Nginx是大型架构的必备中间件,下面我重点详解Nginx如何实现高并发@mikechen文章来源:mikechen.cc事件驱动模型Nginx采用事件驱动模型,这是Nginx高并发性能的基石。传统...
- Spring Boot+Vue全栈开发实战,中文版高清PDF资源
-
SpringBoot+Vue全栈开发实战,中文高清PDF资源,需要的可以私我:)SpringBoot致力于简化开发配置并为企业级开发提供一系列非业务性功能,而Vue则采用数据驱动视图的方式将程序...
- Docker-基础操作_docker基础实战教程二
-
一、镜像1、从仓库获取镜像搜索镜像:dockersearchimage_name搜索结果过滤:是否官方:dockersearch--filter="is-offical=true...
- 你有空吗?跟我一起搭个服务器好不好?
-
来人人都是产品经理【起点学院】,BAT实战派产品总监手把手系统带你学产品、学运营。昨天闲的没事的时候,随手翻了翻写过的文章,发现一个很严重的问题。就是大多数时间我都在滔滔不绝的讲理论,却很少有涉及动手...
- 部署你自己的 SaaS_saas如何部署
-
部署你自己的VPNOpenVPN——功能齐全的开源VPN解决方案。(DigitalOcean教程)dockovpn.io—无状态OpenVPNdockerized服务器,不需要持久存储。...
- Docker Compose_dockercompose安装
-
DockerCompose概述DockerCompose是一个用来定义和管理多容器应用的工具,通过一个docker-compose.yml文件,用YAML格式描述服务、网络、卷等内容,...
- 京东T7架构师推出的电子版SpringBoot,从构建小系统到架构大系统
-
前言:Java的各种开发框架发展了很多年,影响了一代又一代的程序员,现在无论是程序员,还是架构师,使用这些开发框架都面临着两方面的挑战。一方面是要快速开发出系统,这就要求使用的开发框架尽量简单,无论...
- Kubernetes (k8s) 入门学习指南_k8s kubeproxy
-
Kubernetes(k8s)入门学习指南一、什么是Kubernetes?为什么需要它?Kubernetes(k8s)是一个开源的容器编排系统,用于自动化部署、扩展和管理容器化应用程序。它...
欢迎 你 发表评论:
- 一周热门
-
-
抖音上好看的小姐姐,Python给你都下载了
-
全网最简单易懂!495页Python漫画教程,高清PDF版免费下载
-
Python 3.14 的 UUIDv6/v7/v8 上新,别再用 uuid4 () 啦!
-
python入门到脱坑 输入与输出—str()函数
-
宝塔面板如何添加免费waf防火墙?(宝塔面板开启https)
-
Python三目运算基础与进阶_python三目运算符判断三个变量
-
(新版)Python 分布式爬虫与 JS 逆向进阶实战吾爱分享
-
失业程序员复习python笔记——条件与循环
-
慕ke 前端工程师2024「完整」
-
8÷2(2+2) 等于1还是16?国外网友为这道小学数学题吵疯了……
-
- 最近发表
- 标签列表
-
- python计时 (73)
- python安装路径 (56)
- python类型转换 (93)
- python进度条 (67)
- python吧 (67)
- python的for循环 (65)
- python格式化字符串 (61)
- python静态方法 (57)
- python列表切片 (59)
- python面向对象编程 (60)
- python 代码加密 (65)
- python串口编程 (77)
- python封装 (57)
- python写入txt (66)
- python读取文件夹下所有文件 (59)
- python操作mysql数据库 (66)
- python获取列表的长度 (64)
- python接口 (63)
- python调用函数 (57)
- python多态 (60)
- python匿名函数 (59)
- python打印九九乘法表 (65)
- python赋值 (62)
- python异常 (69)
- python元祖 (57)
