1.创建一个TCP链接
struct netconn* //内存错误时NULL或 新分配的struct netconn
netconn_new_with_proto_and_callback(
enum netconn_type t, // t是要创建的“连接”类型(@see enum netconn_type)
u8_t proto, //proto是RAW IP pcbs的IP协议
netconn_callback callback //callback是回调调用状态变化的函数
)
enum netconn_type {
NETCONN_INVALID = 0,
/* NETCONN_TCP Group /
NETCONN_TCP = 0x10,
/ NETCONN_UDP Group /
NETCONN_UDP = 0x20,
NETCONN_UDPLITE = 0x21,
NETCONN_UDPNOCHKSUM= 0x22,
/ NETCONN_RAW Group */
NETCONN_RAW = 0x40
};
2.绑定端口 8088号端口
err_t //错误码,成功的话就是ERR_OK
netconn_bind(
struct netconn *conn, 创建tcp连接时候返回的套接字
ip_addr_t addr, IP地址 这里用的是0.0.0.0可以连接所有的ip
u16_t port 端口号 这里是8088 用户可以修改
)
下面就是一些错误码
#define ERR_OK 0 / No error, everything OK. /
#define ERR_MEM -1 / Out of memory error. /
#define ERR_BUF -2 / Buffer error. /
#define ERR_TIMEOUT -3 / Timeout. /
#define ERR_RTE -4 / Routing problem. /
#define ERR_INPROGRESS -5 / Operation in progress /
#define ERR_VAL -6 / Illegal value. /
#define ERR_WOULDBLOCK -7 / Operation would block. /
#define ERR_USE -8 / Address in use. /
#define ERR_ISCONN -9 / Already connected. */
3.开启监听模式 等待连接
err_t
netconn_listen_with_backlog(
struct netconn *conn, 创建tcp连接时候返回的套接字
u8_t backlog // the listen backlog, only used if TCP_LISTEN_BACKLOG==1
)
4.连接
err_t
netconn_accept(
struct netconn *conn, //创建tcp连接时候返回的套接字
struct netconn **new_conn //存储新连接的指针
)
5.获取自己或对方的ip和端口号
err_t
netconn_getaddr(
struct netconn *conn,//新连接的指针(套接字)
ip_addr_t *addr, //addr指向要保存IP地址的指针
u16_t *port, //一个指针,用于保存端口(或RAW的协议)
u8_t local //1获取本地IP地址,0获取远程IP地址
)
返回值:ERR_CONN用于无效连接 如果检索到信息,则为ERR_OK
6.关闭连接和删除连接
netconn_close(newconn);
netconn_delete(newconn);
stm32 tcp_ip协议函数接口的使用笔记
最新推荐文章于 2025-07-17 08:18:20 发布