网络实验9 NETCONN_TCP 服务器,改网路连接功能的一部分代码,程序会跑飞,哪位大神帮忙分析下。

2019-07-21 03:23发布

问题描述,该实验程序其他地方都没有变化,只改动了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;
}



友情提示: 此问题已得到解决,问题已经关闭,关闭后问题禁止继续编辑,回答。