[ESP32/ESP8266专题笔记-4] ESP32开发板-Micropython-TCP 远程通信

ESP32开发板-Micropython-TCP 远程通信控制LED操作

1 硬件篇,确定连接LED的GPIO口

2 软件篇

(1)ESP32能控制灯亮灭
from machine import Pin # 导入Pin模块
from utime import sleep_ms #导入延时函数

def led(control_cmd):
    LED = Pin(22,Pin.OUT) # 构建 LED 对象,GPIO22 输出
    if control_cmd == "灯亮":
        LED.value(0)  # 点亮LED
    elif control_cmd == "灯灭":
        LED.value(1)  # 熄灭LED
    elif control_cmd == "灯闪":
        for i in range(3):
            LED.value(0)  # 点亮LED
            sleep_ms(300)
            LED.value(1)  # 熄灭LED
            sleep_ms(400)

(2)ESP32能连接局域网(使用内置wifi)
import network

ssid = "wifi名"
passwd = "wifi密码"
def connectWifi(ssid,passwd):
    global wlan
    wlan=network.WLAN(network.STA_IF)         #create a wlan object
    wlan.active(True)                         #Activate the network interface
    wlan.disconnect()                         #Disconnect the last connected WiFi
    wlan.connect(ssid,passwd)                 #connect wifi
    while(wlan.ifconfig()[0]=='0.0.0.0'):
        time.sleep(1)
    return True

(3)创建tcp服务,接收tcp网络消息
def connectWifi(ssid,passwd):
    global wlan
    wlan=network.WLAN(network.STA_IF)         #create a wlan object
    wlan.active(True)                         #Activate the network interface
    wlan.disconnect()                         #Disconnect the last connected WiFi
    wlan.connect(ssid,passwd)                 #connect wifi
    while(wlan.ifconfig()[0]=='0.0.0.0'):
        time.sleep(1)
    return True
try:
    connectWifi(SSID,PASSWORD)
    ip=wlan.ifconfig()[0]                    
    listenSocket = socket.socket()            
    listenSocket.bind((ip,port))  
    listenSocket.listen(1)                
    listenSocket.setsockopt(socket.SOL_SOCKET, socket.SO_REUSEADDR, 1)    
    print("*"*90)
    print("TCP 服务器开启, IP: %s PORT: %s"%(ip, port))
    print("*"*90)
    while True:
        print("等待消息接收 ...")
        conn,addr = listenSocket.accept()  
        print("连接自 ...",addr)
        while True:
            data = conn.recv(1024)           
            if(len(data) == 0):
                print("接收完成 ......")
                conn.close()                    
                break
            message_content  = data.decode()
            led(message_content)
            print("\033[0;36;32m接收消息内容: [%s]\033[0m"%message_content)
            ret = conn.send(data)#send data
except:
    if(listenSocket):
        listenSocket.close()
    wlan.disconnect()
    wlan.active(False)
                          
(4)创建tcp服务,完整代码
#ESP32上运行相关代码
import network
import socket
import time
from machine import Pin # 导入Pin模块
from utime import sleep_ms #导入延时函数

SSID="WIFI名称"
PASSWORD="WIFI密码"
port=10000
wlan=None
listenSocket=None

def led(control_cmd):
    LED = Pin(22,Pin.OUT) # 构建 LED 对象,GPIO22 输出
    if control_cmd == "灯亮":
        LED.value(0)  # 点亮LED
    elif control_cmd == "灯灭":
        LED.value(1)  # 熄灭LED
    elif control_cmd == "灯闪":
        for i in range(3):
            LED.value(0)  # 点亮LED
            sleep_ms(300)
            LED.value(1)  # 熄灭LED
            sleep_ms(400)



def connectWifi(ssid,passwd):
    global wlan
    wlan=network.WLAN(network.STA_IF)     
    wlan.active(True)              
    wlan.disconnect()               
    wlan.connect(ssid,passwd)         
    while(wlan.ifconfig()[0]=='0.0.0.0'):
        time.sleep(1)
    return True


try:
    connectWifi(SSID,PASSWORD)
    ip=wlan.ifconfig()[0]                   
    listenSocket = socket.socket()            
    listenSocket.bind((ip,port))           
    listenSocket.listen(1)                  
    listenSocket.setsockopt(socket.SOL_SOCKET, socket.SO_REUSEADDR, 1)   
    print("*"*90)
    print("TCP 服务器开启, IP: %s PORT: %s"%(ip, port))
    print("*"*90)
    while True:
        print("等待消息接收 ...")
        conn,addr = listenSocket.accept()    
        print("连接自 ...",addr)
        while True:
            data = conn.recv(1024)            
            if(len(data) == 0):
                print("接收完成 ......")
                conn.close()               
                break
            message_content  = data.decode()
            led(message_content)
            print("\033[0;36;32m接收消息内容: [%s]\033[0m"%message_content)
            ret = conn.send(data)
except:
    if(listenSocket):
        listenSocket.close()
    wlan.disconnect()
    wlan.active(False)

(5)下载代码至ESP32内
sudo ampy --port /dev/ttyUSB0 put main.py
(6)PC控制端代码,用于发送控制指令
#!/usr/bin/env python3
# -*- coding:utf-8 -*-
#-----------------------------------------
import socket

class TcpClient:
    def __init__(self, PORT, HOST, BUFSIZ):
        """
            功能:   初始化tcp参数
            参数:  PORT 端口
                    HOST ip地址
                    BUFSIZ buf 大小/字节
            返回值: 无
        """
        self.PORT = PORT
        self.HOST = str(HOST)
        self.BUFSIZ = BUFSIZ

    def TcpSend(self, sendMsg):
        """
            功能:   发送TCP 指令到指定ip及端口中
            参数:  发送命令字符串
            返回值: bool: True/False
        """
        ADDR = (self.HOST, self.PORT)
        s = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
        s.connect(ADDR)

        s.send(sendMsg.encode())
        RX_DATA = s.recv(self.BUFSIZ)
        #接收数据编码转换
        RX_DATA = RX_DATA.decode()
        s.close()
        if RX_DATA == sendMsg:
            print("\033[0;36;32m[TCP消息服务]: {消息: %s} 发送成功\033[0m"%sendMsg)
            return True
        else:
            print("\033[0;36;31m[TCP消息服务]: {消息: %s} 发送失败\033[0m"%sendMsg)
            return False
        #s.send('exit'.encode())


if __name__=="__main__":
    tcp = TcpClient(10000, "192.168.xxx.xxx", 1024)
    while True:
        send_cmd = input("发送指令:")
        tcp.TcpSend(send_cmd)

(7)移动控制端代码,用于发送控制指令(网络调试助手)

手机网络调试助手界面

版权声明:本文为CSDN博主「小树笔记」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/weixin_41596275/article/details/122926164

生成海报
点赞 0

小树笔记

我还没有学会写个人说明!

暂无评论

发表评论

相关推荐

芯片设计IP核公司总结与分析

下图是IPnest公司在2020年4月发布的关于2018年和2019年全球 最大的10家芯片设计IP核公司名单。 芯片设计难度挺大但也不是很多人想象的从0开始的那种难,绝大部分芯片设计公司都是买IP核然后整合一下,最

STM32F103基于W5500实现Modbus简单TCP通信

一、Modbus/TCP协议 功能码作用01读取线圈状态02读取输入状态03读取保持寄存器04读取输入寄存器05强置单线圈06预置单寄存器07读取异常状态08回送诊断校验09编程(只用于484)0A控询0B读取事件

W5500+STM32F103C8T6进行TCP通信(modbus)

一、W5500以太网模块介绍 Niren_W5500模块是一款基于WIZnet W5500芯片的以太网模块,是泥人电子继 Niren_W5100模块后设计的一块性能更好、性价比更高的以太网模块。模块集成硬件化TCP/IP协议:内