Toggle navigation
首页
问答
文章
积分商城
专家
专区
更多专区...
文档中心
返回主站
搜索
提问
会员
中心
登录
注册
网络学习营
【网络编程学习】+3.2kg+实现一个简单的TCP聊天客户端
发布于 2018-08-02 23:55:04 浏览:2668
订阅该版
* 本帖最后由 涛声依旧 于 2018-8-2 23:55 编辑 * **第一周作业** 题目如下:  在熟悉RT-thread网络编程后,利用tcpclient历程实现一个简单的客户端。 思路分析: 通过msh命令输入服务器IP地址和端口和客户端id。输入后程序会自动创建tcp客户端处理线程。线程创建成功后,创建socket,连接指定服务器ip地址和目标端口。服务器连接成功后再发送login命令,在发送look命令,查看聊天室有哪些人。在发送say命令和who命令。最后logout退出。 实施过程: 1. 拷贝“tcpclient”文件夹,重命名为“chatclient”,里面的.c源文件名字也改为“chatclient.c”。如图:  修改SConscript文件。增加源文件和路径。这里增加了一个宏:RT_USING_SAMPLE_CHAT_CLIENT,在rtconfig.h文件添加编译选项。如图: 使用命令连接创建线程连接聊天服务器。 void chat_setup(int argc, char **argv) { /* 创建test线程 */ tid = rt_thread_create("chatclient", tcp_chat_thread, argv,//传入服务器ip地址与端口 1024, 10, 20); /* 创建成功则启动线程 */ if (tid != RT_NULL) rt_thread_startup(tid); } MSH_CMD_EXPORT(chat_setup, chat_setup); void tcp_chat_thread(char **argv) { int ret; char *recv_data; struct hostent *host; int bytes_received; struct sockaddr_in server_addr; const char *url; int port; 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); rt_thread_delete(tid); 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); rt_thread_delete(tid); return; } bytes_received = recv(sock, recv_data, BUFSZ - 1, 0); /* 有接收到数据,把末端清零 */ recv_data[bytes_received] = '\0'; /* 在控制终端显示收到的数据 */ rt_kprintf("
Received data = %s ", recv_data); while (1) { chat_send(recv_data); /* 从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'; /* 在控制终端显示收到的数据 */ rt_kprintf("
Received data = %s ", recv_data); } return; } 然后用vscode修改代码,使用scons命令编译。         
查看更多
0
个回答
默认排序
按发布时间排序
暂无答案,快来添加答案吧
撰写答案
登录
注册新账号
关注者
0
被浏览
2.7k
关于作者
涛声依旧
这家伙很懒,什么也没写!
提问
6
回答
4
被采纳
1
关注TA
发私信
相关问题
1
【LWIP学习营】第一关开发环境搭建
2
LWIP学习营第一周入门移植问题汇总贴
3
【LWIP学习营】f407+lan8720A小结
4
【LwIP学习营】【第一周】仅零散记录,无主题
5
【LWIP学习营】正点原子探索者F407+LAN8720第一周小结
6
【LwIP学习营】【第一周】网络通信基础及实现TCP 聊天客户端
7
【LwIP学习营】【第一周】LWIP移植
8
【LwIP学习营】【第一周】LWIP移植
9
【LwIP学习营】【第一周】开发板适配
10
【LwIP学习营】【第一周】环境搭建和配置验证
推荐文章
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
RT-Thread OS应用开发实战线上师资培训通知
2
【ci】【github】【bsp】RT-Thread仓库的CI自动编译测试
3
免费解锁MCU超能力!4月AIoT实战培训三城巡演
4
rt-thread主仓 BSP瘦身指南
5
Studio环境下ST M7系列USB主机(CherryUSB)配置及踩坑
热门标签
RT-Thread Studio
串口
Env
LWIP
SPI
AT
Bootloader
Hardfault
CAN总线
FinSH
ART-Pi
DMA
USB
文件系统
RT-Thread
SCons
RT-Thread Nano
线程
MQTT
STM32
rt-smart
RTC
FAL
I2C_IIC
cubemx
ESP8266
WIZnet_W5500
UART
ota在线升级
PWM
BSP
flash
freemodbus
packages_软件包
潘多拉开发板_Pandora
GD32
定时器
ADC
flashDB
编译报错
socket
中断
rt_mq_消息队列_msg_queue
keil_MDK
Debug
SFUD
msh
ulog
C++_cpp
at_device
本月问答贡献
RTT_逍遥
4
个答案
2
次被采纳
聚散无由
3
个答案
2
次被采纳
踩姑娘的小蘑菇
5
个答案
1
次被采纳
a1012112796
4
个答案
1
次被采纳
YZRD
2
个答案
1
次被采纳
本月文章贡献
出出啊
1
篇文章
2
次点赞
小小李sunny
1
篇文章
1
次点赞
张世争
1
篇文章
2
次点赞
crystal266
2
篇文章
1
次点赞
whj467467222
2
篇文章
1
次点赞
回到
顶部
发布
问题
分享
好友
手机
浏览
扫码手机浏览
投诉
建议
回到
底部