Toggle navigation
首页
问答
文章
积分商城
专家
专区
更多专区...
文档中心
返回主站
搜索
提问
会员
中心
登录
注册
Network
TCP Connect fail,求助~
发布于 2019-10-06 20:20:40 浏览:2859
订阅该版
使用时出现TCP无法连接的情况 目前LWIP已经能跑起来,可以Ping通,但是使用实例程序时出现TCp无法连接的情况,MSH输出的Log如下 ``` tcpclient 192.168.1.9 50010 lwip_socket(PF_INET, SOCK_STREAM, 0) = 0 lwip_connect(0, addr=192.168.1.9 port=50010) lwip_connect(0) failed, err=-4 Connect fail! lwip_close(0) ``` 其中 192.168.1.9是我的PC,PC已经使用网络助手开启了TCP Server,监听端口为 50010,192.168.1.30为设备端 使用PC的ping命令可以Ping通,如下所示: ``` Reply from 192.168.1.30: bytes=32 time=1ms TTL=255 Reply from 192.168.1.30: bytes=32 time<1ms TTL=255 Reply from 192.168.1.30: bytes=32 time<1ms TTL=255 Reply from 192.168.1.30: bytes=32 time=1ms TTL=255 Reply from 192.168.1.30: bytes=32 time=1ms TTL=255 Reply from 192.168.1.30: bytes=32 time=1ms TTL=255 ``` TCP Client例程如下 ```c /* * Copyright (c) 2006-2018, RT-Thread Development Team * * SPDX-License-Identifier: Apache-2.0 * * Change Logs: * Date Author Notes * */ /* * 程序清单:tcp 客户端 * * 这是一个 tcp 客户端的例程 * 导出 tcpclient 命令到控制终端 * 命令调用格式:tcpclient URL PORT * URL:服务器地址 PORT::端口号 * 程序功能:接收并显示从服务端发送过来的信息,接收到开头是 'q' 或 'Q' 的信息退出程序 */ #include
#include
/* 使用BSD socket,需要包含socket.h头文件 */ #include
#include
#include
#define BUFSZ 1024 static const char send_data[] = "This is TCP Client from RT-Thread."; /* 发送用到的数据 */ void tcpclient(int argc, char **argv) { int ret; char *recv_data; struct hostent *host; int sock, bytes_received; struct sockaddr_in server_addr; const char *url; int port; if (argc < 3) { rt_kprintf("Usage: tcpclient URL PORT
"); rt_kprintf("Like: tcpclient 192.168.1.9 50010
"); return ; } url = argv[1]; port = strtoul(argv[2], 0, 10); /* 通过函数入口参数url获得host地址(如果是域名,会做域名解析) */ host = gethostbyname(url); /* 分配用于存放接收数据的缓冲 */ recv_data = rt_malloc(BUFSZ); if (recv_data == RT_NULL) { rt_kprintf("No memory
"); return; } /* 创建一个socket,类型是SOCKET_STREAM,TCP类型 */ if ((sock = socket(AF_INET, SOCK_STREAM, 0)) == -1) { /* 创建socket失败 */ rt_kprintf("Socket error
"); /* 释放接收缓冲 */ rt_free(recv_data); return; } /* 初始化预连接的服务端地址 */ server_addr.sin_family = AF_INET; server_addr.sin_port = htons(port); server_addr.sin_addr = *((struct in_addr *)host->h_addr); rt_memset(&(server_addr.sin_zero), 0, sizeof(server_addr.sin_zero)); /* 连接到服务端 */ if (connect(sock, (struct sockaddr *)&server_addr, sizeof(struct sockaddr)) == -1) { /* 连接失败 */ rt_kprintf("Connect fail!
"); closesocket(sock); /*释放接收缓冲 */ rt_free(recv_data); return; } while (1) { /* 从sock连接中接收最大BUFSZ - 1字节数据 */ bytes_received = recv(sock, recv_data, BUFSZ - 1, 0); if (bytes_received < 0) { /* 接收失败,关闭这个连接 */ closesocket(sock); rt_kprintf("
received error,close the socket.
"); /* 释放接收缓冲 */ rt_free(recv_data); break; } else if (bytes_received == 0) { /* 默认 recv 为阻塞模式,此时收到0认为连接出错,关闭这个连接 */ closesocket(sock); rt_kprintf("
received error,close the socket.
"); /* 释放接收缓冲 */ rt_free(recv_data); break; } /* 有接收到数据,把末端清零 */ recv_data[bytes_received] = '\0'; if (strncmp(recv_data, "q", 1) == 0 || strncmp(recv_data, "Q", 1) == 0) { /* 如果是首字母是q或Q,关闭这个连接 */ closesocket(sock); rt_kprintf("
got a 'q' or 'Q',close the socket.
"); /* 释放接收缓冲 */ rt_free(recv_data); break; } else { /* 在控制终端显示收到的数据 */ rt_kprintf("
Received data = %s ", recv_data); } /* 发送数据到sock连接 */ ret = send(sock, send_data, strlen(send_data), 0); if (ret < 0) { /* 接收失败,关闭这个连接 */ closesocket(sock); rt_kprintf("
send error,close the socket.
"); rt_free(recv_data); break; } else if (ret == 0) { /* 打印send函数返回值为0的警告信息 */ rt_kprintf("
Send warning,send function return 0.
"); } } return; } MSH_CMD_EXPORT(tcpclient, a tcp client sample); ``` 经测试,不仅是TCP Client有问题,TCP Server和UDP都不能正常通信... 断点跟进,发现会进入到lwip_connect函数的这个语句`"lwip_connect: invalid address"` ```c LWIP_ERROR("lwip_connect: invalid address", IS_SOCK_ADDR_LEN_VALID(namelen) && IS_SOCK_ADDR_TYPE_VALID_OR_UNSPEC(name) && IS_SOCK_ADDR_ALIGNED(name), sock_set_errno(sock, err_to_errno(ERR_ARG)); return -1;); ``` 以下是 lwip_connect 函数 ```c int lwip_connect(int s, const struct sockaddr *name, socklen_t namelen) { struct lwip_sock *sock; err_t err; sock = get_socket(s); if (!sock) { return -1; } if (!SOCK_ADDR_TYPE_MATCH_OR_UNSPEC(name, sock)) { /* sockaddr does not match socket type (IPv4/IPv6) */ sock_set_errno(sock, err_to_errno(ERR_VAL)); return -1; } LWIP_UNUSED_ARG(namelen); if (name->sa_family == AF_UNSPEC) { LWIP_DEBUGF(SOCKETS_DEBUG, ("lwip_connect(%d, AF_UNSPEC)
", s)); err = netconn_disconnect(sock->conn); } else { ip_addr_t remote_addr; u16_t remote_port; /* check size, family and alignment of 'name' */ LWIP_ERROR("lwip_connect: invalid address", IS_SOCK_ADDR_LEN_VALID(namelen) && IS_SOCK_ADDR_TYPE_VALID_OR_UNSPEC(name) && IS_SOCK_ADDR_ALIGNED(name), sock_set_errno(sock, err_to_errno(ERR_ARG)); return -1;); SOCKADDR_TO_IPADDR_PORT(name, &remote_addr, remote_port); LWIP_DEBUGF(SOCKETS_DEBUG, ("lwip_connect(%d, addr=", s)); ip_addr_debug_print_val(SOCKETS_DEBUG, remote_addr); LWIP_DEBUGF(SOCKETS_DEBUG, (" port=%"U16_F")
", remote_port)); #if LWIP_IPV4 && LWIP_IPV6 /* Dual-stack: Unmap IPv4 mapped IPv6 addresses */ if (IP_IS_V6_VAL(remote_addr) && ip6_addr_isipv4mappedipv6(ip_2_ip6(&remote_addr))) { unmap_ipv4_mapped_ipv6(ip_2_ip4(&remote_addr), ip_2_ip6(&remote_addr)); IP_SET_TYPE_VAL(remote_addr, IPADDR_TYPE_V4); } #endif /* LWIP_IPV4 && LWIP_IPV6 */ err = netconn_connect(sock->conn, &remote_addr, remote_port); } if (err != ERR_OK) { LWIP_DEBUGF(SOCKETS_DEBUG, ("lwip_connect(%d) failed, err=%d
", s, err)); sock_set_errno(sock, err_to_errno(err)); return -1; } LWIP_DEBUGF(SOCKETS_DEBUG, ("lwip_connect(%d) succeeded
", s)); sock_set_errno(sock, 0); return 0; } ``` 请大神们指点迷津~
查看更多
14
个回答
默认排序
按发布时间排序
yutian0606
2022-05-20
这家伙很懒,什么也没写!
帮忙解决了问题,顶一下。 问题描述: 移植完 wiznet 软件包后,发现电脑可以 ping 通开发板, 但是开发板不能ping通电脑, 开发板移植的应用代码也连接不上电脑的 tcp 服务端,按本帖提示,电脑系统 WIN10 自带的防火墙关闭后就正常了。👍👍
tyustli
2019-10-06
这家伙很懒,什么也没写!
ifconfig 看一下网段,以前也遇到过这种,好像和网段有关系
wofei1314
2019-10-06
这家伙很懒,什么也没写!
>ifconfig 看一下网段,以前也遇到过这种,好像和网段有关系 --- [attach]11220[/attach] 网段都是192.168.1.x
艾那的小强
2019-10-07
这家伙很懒,什么也没写!
防火墙入站规则设置一下,或者关闭防火墙。
艾那的小强
2019-10-07
这家伙很懒,什么也没写!
防火墙入站规则设置一下,或者关闭防火墙。
wofei1314
2019-10-07
这家伙很懒,什么也没写!
>防火墙入站规则设置一下,或者关闭防火墙。 谢谢,不是这个原因 这个是LWIP1.4.1的,这个是可以链接的,对比了下,主要差异是在这儿,可以用的Flag是 LINK_UP,连接失败的是Flag是`LINK_DOWN` `FLAGS: UP LINK_UP ETHARP IGMP` 看起来像是网卡未启用?但是两个版本都是可以Ping通的.... ``` \ | / - RT - Thread Operating System / | \ 4.0.1 build Oct 7 2019 2006 - 2019 Copyright by rt-thread team lwIP-1.4.1 initialized! msh />ifc ifconfig msh />ifconfig network interface: e0 (Default) MTU: 1500 MAC: 02 00 00 00 00 00 FLAGS: UP LINK_UP ETHARP IGMP ip address: 192.168.1.30 gw address: 192.168.1.1 net mask : 255.255.255.0 ```
学长啊啊啊
2019-10-08
这家伙很懒,什么也没写!
端口号改小点试试呢?
RickFlying
2019-11-24
something in the way
楼主我也遇到类似的情况了,lwip移植成功,按照官方教程,开启相关其他配置之后,在PC上用网络调试助手连接就会提示找不到连接对象,请问你是怎么解决的? 附加: 刚刚已经解决,我的问题是,笔记本连网线不能开wifi,然后笔记本防火墙全部关闭就OK了/
hichard
认证专家
2019-11-24
这家伙很懒,什么也没写!
明显就是防火墙问题
wofei1314
2019-11-30
这家伙很懒,什么也没写!
>明显就是防火墙问题 这么明显吗? ``` FLAGS: UP LINK_DOWN INTERNET_DOWN DHCP_DISABLE ETHARP BROADCAST IGMP ``` 这里有个`“LINK_DOWN ”`看来不明显啊
撰写答案
登录
注册新账号
关注者
0
被浏览
2.9k
关于作者
wofei1314
这家伙很懒,什么也没写!
提问
4
回答
17
被采纳
0
关注TA
发私信
相关问题
1
lwip1.4.1连接经常会断开无法连接上,可以ping通
2
LPC1768:RTT+LWIP+webserver用IE刷网页出现硬件中断错误(已经解决)
3
求一些LWIP开发的经验,目前ping一直不稳定。
4
stm32f207+dp83848无法ping通
5
RTT下的LWIP传递机制
6
rtt内lwip的socket是否是线程安全?
7
Lwip+enc28j60无法ping通
8
坑爹的rtconfig.h lwip关掉了checksum
9
花了一个晚上,把RT2.0的LWIP、网卡驱动、文件系统整合起来了,发现一点小问题
10
lwip例程中udp发送时如何指定源端口发送到指定目的地端口
推荐文章
1
RT-Thread应用项目汇总
2
玩转RT-Thread系列教程
3
国产MCU移植系列教程汇总,欢迎查看!
4
机器人操作系统 (ROS2) 和 RT-Thread 通信
5
五分钟玩转RT-Thread新社区
6
【技术三千问】之《玩转ART-Pi》,看这篇就够了!干货汇总
7
关于STM32H7开发板上使用SDIO接口驱动SD卡挂载文件系统的问题总结
8
STM32的“GPU”——DMA2D实例详解
9
RT-Thread隐藏的宝藏之completion
10
【ART-PI】RT-Thread 开启RTC 与 Alarm组件
最新文章
1
在用clangd开发RTT吗,快来试试如何简单获得清晰干净的工作区
2
GD32F450 片内 flash驱动适配
3
STM32H7R7运行CherryUSB
4
RT-Smart首次线下培训,锁定2024 RT-Thread开发者大会!
5
使用RC522软件包驱动FM1722
热门标签
RT-Thread Studio
串口
Env
LWIP
SPI
AT
Bootloader
Hardfault
CAN总线
FinSH
ART-Pi
USB
DMA
文件系统
RT-Thread
SCons
RT-Thread Nano
线程
MQTT
STM32
RTC
FAL
rt-smart
ESP8266
I2C_IIC
UART
WIZnet_W5500
ota在线升级
PWM
freemodbus
flash
cubemx
packages_软件包
BSP
潘多拉开发板_Pandora
定时器
ADC
flashDB
GD32
socket
中断
编译报错
Debug
SFUD
rt_mq_消息队列_msg_queue
msh
keil_MDK
ulog
C++_cpp
MicroPython
本月问答贡献
a1012112796
10
个答案
1
次被采纳
踩姑娘的小蘑菇
4
个答案
1
次被采纳
红枫
4
个答案
1
次被采纳
张世争
4
个答案
1
次被采纳
Ryan_CW
4
个答案
1
次被采纳
本月文章贡献
catcatbing
3
篇文章
6
次点赞
YZRD
2
篇文章
5
次点赞
qq1078249029
2
篇文章
2
次点赞
xnosky
2
篇文章
1
次点赞
Woshizhapuren
1
篇文章
5
次点赞
回到
顶部
发布
问题
分享
好友
手机
浏览
扫码手机浏览
投诉
建议
回到
底部