问题描述,该实验程序其他地方都没有变化,只改动了tcp_server_demo.c文件。改动如下:
用网络调试助手V3.8软件,选择客户端模式,连接后,任意发送个数据,stm32f407做为服务器,回向计算机循环发送10个数据,网络调试助手V3.8软件再断开连接,再连接,再断开,就无法再连接上,程序就不会有反映,应该是跑飞。哪位大神帮忙分析下产生的原因,该如何解决。
#include "tcp_server_demo.h"
#include "lwip/opt.h"
#include "lwip_comm.h"
#include "led.h"
#include "lwip/lwip_sys.h"
#include "lwip/api.h"
//////////////////////////////////////////////////////////////////////////////////
//本程序只供学习使用,未经作者许可,不得用于其它任何用途
//ALIENTEK STM32F407开发板
//NETCONN API编程方式的TCP服务器测试代码
//正点原子@ALIENTEK
//技术论坛:www.openedv.com
//创建日期:2014/8/15
//版本:V1.0
//版权所有,盗版必究。
//Copyright(C) 广州市星翼电子科技有限公司 2009-2019
//All rights reserved
//*******************************************************************************
//修改信息
//无
//////////////////////////////////////////////////////////////////////////////////
u8 tcp_server_recvbuf[TCP_SERVER_RX_BUFSIZE]; //TCP客户端接收数据缓冲区
u8 *tcp_server_sendbuf="Explorer STM32F407 NETCONN TCP Server send data
";
u8 tcp_server_flag; //TCP服务器数据发送标志位
//TCP客户端任务
#define TCPSERVER_PRIO 6
//任务堆栈大小
#define TCPSERVER_STK_SIZE 300
//任务堆栈
OS_STK TCPSERVER_TASK_STK[TCPSERVER_STK_SIZE];
//tcp服务器任务
static void tcp_server_thread(void *arg)
{
OS_CPU_SR cpu_sr;
u32 data_len = 0;
struct pbuf *q;
err_t err,recv_err,net_err,data_err;
u8 remot_addr[4];
struct netconn *conn, *newconn;
static ip_addr_t ipaddr;
static u16_t port;
void *data="",*data1="1234";
int i;
u16_t len;
LWIP_UNUSED_ARG(arg);
conn = netconn_new(NETCONN_TCP); //创建一个TCP链接
netconn_bind(conn,IP_ADDR_ANY,2048); //绑定端口 8号端口
netconn_listen(conn); //进入监听模式
conn->recv_timeout = 10; //禁止阻塞线程 等待10ms
while (1)
{
err = netconn_accept(conn,&newconn); //接收连接请求
newconn->recv_timeout = 10;
if (err == ERR_OK) //处理新连接的数据
{
struct netbuf *recvbuf;
netconn_getaddr(newconn,&ipaddr,&port,0); //获取远端IP地址和端口号
remot_addr[3] = (uint8_t)(ipaddr.addr >> 24);
remot_addr[2] = (uint8_t)(ipaddr.addr>> 16);
remot_addr[1] = (uint8_t)(ipaddr.addr >> 8);
remot_addr[0] = (uint8_t)(ipaddr.addr);
printf("接收到主机:%d.%d.%d.%d发送连接请求
",remot_addr[0], remot_addr[1],remot_addr[2],remot_addr[3]);
LCD_ShowString(30,310,210,16,16,"have receive netconn_ask");
delay_ms(1000);
printf("主机%d.%d.%d.%d连接上服务器,主机端口号为:%d
",remot_addr[0], remot_addr[1],remot_addr[2],remot_addr[3],port);
LCD_ShowString(30,290,210,16,16,"net_connect");
while(1)
{
recv_err = netconn_recv(newconn,&recvbuf);
if(recv_err == ERR_OK) //接收到数据
{
netbuf_data(recvbuf, &data, &len);
printf("收到的数据:%s
",data); //通过串口发送接收到的数据
LCD_ShowString(30,250,200,20,16,"receive data is :");
LCD_ShowString(200,250,210,16,16,data);
delay_ms(1000);
for(i=0;i<10;i++)
{
data_err = netconn_write(newconn, data1, 4, NETCONN_COPY);
printf("发送的数据:%s
",data1); //通过串口发送接收到的数据
LCD_ShowString(30,270,200,20,16,"send data is :");
LCD_ShowString(200,270,210,16,16,data1);
delay_ms(500);
if(data_err!= ERR_OK)
{
printf("发送失败
");
LCD_ShowString(30,330,210,16,16,"send data failed");
}
else
{
printf("发送成功
");
LCD_ShowString(30,330,210,16,16,"send data success");
}
delay_ms(500);
net_err = netconn_recv(newconn,&recvbuf);//判断上位机是否有发数据
if(net_err == ERR_CLSD)
{
break;
}
printf("发送进行中
");
LCD_ShowString(30,350,210,16,16,"send data now");
}
printf("发送结束
");
LCD_ShowString(30,350,210,16,16,"send data over");
netbuf_delete(recvbuf);
data="";
}
else if(recv_err == ERR_CLSD) //关闭连接
{
netconn_close(newconn);
netconn_delete(newconn);
printf("主机:%d.%d.%d.%d断开与服务器的连接
",remot_addr[0], remot_addr[1],remot_addr[2],remot_addr[3]);
LCD_ShowString(30,290,210,16,16,"net_delete");
break;
}
}//第二个while的
}
else
// printf("主机:%d.%d.%d.%d断开与服务器的连接
",remot_addr[0], remot_addr[1],remot_addr[2],remot_addr[3]);
LCD_ShowString(30,290,210,16,16,"net_delete");
// printf("主机:%d.%d.%d.%d没有发送连接请求
",remot_addr[0], remot_addr[1],remot_addr[2],remot_addr[3]);
LCD_ShowString(30,310,210,16,16,"no netconn_ask");
LCD_ShowString(30,330,210,16,16,"not send data");
}//第一个while的
}
//创建TCP服务器线程
//返回值:0 TCP服务器创建成功
// 其他 TCP服务器创建失败
INT8U tcp_server_init(void)
{
INT8U res;
OS_CPU_SR cpu_sr;
OS_ENTER_CRITICAL(); //关中断
res = OSTaskCreate(tcp_server_thread,(void*)0,(OS_STK*)&TCPSERVER_TASK_STK[TCPSERVER_STK_SIZE-1],TCPSERVER_PRIO); //创建TCP服务器线程
OS_EXIT_CRITICAL(); //开中断
return res;
}
一周热门 更多>