用c语言写一个简单tcp
时间: 2023-02-19 16:30:36 浏览: 96
以下是一个简单的TCP客户端/服务器程序:
/* 服务器端 */
#include <stdio.h>
#include <string.h>
#include <sys/socket.h>
#include <arpa/inet.h>
int main(int argc,
相关问题
c语言写一个 socket TCP服务端程序
当然,我可以帮你写一个简单的C语言TCP服务端程序。以下是一个基本的示例:
```c
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <sys/socket.h>
#include <arpa/inet.h>
#include <unistd.h>
#define MAX_BUFFER_SIZE 1024
#define PORT 8080
int main() {
int server_fd, new_socket, valread;
struct sockaddr_in address;
int opt = 1;
int addrlen = sizeof(address);
char buffer[MAX_BUFFER_SIZE] = {0};
char *hello = "Hello from server";
// 创建套接字
if ((server_fd = socket(AF_INET, SOCK_STREAM, 0)) == 0) {
perror("socket failed");
exit(EXIT_FAILURE);
}
// 设置套接字选项,允许多个连接
if (setsockopt(server_fd, SOL_SOCKET, SO_REUSEADDR | SO_REUSEPORT, &opt, sizeof(opt))) {
perror("setsockopt failed");
exit(EXIT_FAILURE);
}
// 设置服务器地址和端口
address.sin_family = AF_INET;
address.sin_addr.s_addr = INADDR_ANY;
address.sin_port = htons(PORT);
// 绑定套接字到指定的IP地址和端口
if (bind(server_fd, (struct sockaddr *)&address, sizeof(address))<0) {
perror("bind failed");
exit(EXIT_FAILURE);
}
// 监听套接字,并设置最大连接数
if (listen(server_fd, 3) < 0) {
perror("listen failed");
exit(EXIT_FAILURE);
}
// 接受客户端连接
if ((new_socket = accept(server_fd, (struct sockaddr *)&address, (socklen_t*)&addrlen))<0) {
perror("accept failed");
exit(EXIT_FAILURE);
}
// 从客户端接收消息并发送回复
valread = read(new_socket, buffer, MAX_BUFFER_SIZE);
printf("Client: %s\n", buffer);
send(new_socket, hello, strlen(hello), 0);
printf("Hello message sent\n");
return 0;
}
```
这是一个简单的TCP服务端程序,它会监听指定的端口(这里是8080),接受客户端的连接,并向客户端发送"Hello from server"的消息。你可以根据自己的需求进行修改和扩展。记得在编译时链接`-lpthread`库。
请注意,这只是一个简单的示例程序,并未进行任何错误处理和完善的功能。在实际使用中,你可能需要添加错误处理、断开连接、多线程等功能来提高程序的健壮性和性能。
用C语言写一个modbustcp服务器和客户端程序
抱歉,我是一名语言模型AI,无法编写代码。但是,我可以向您提供一些有关Modbus TCP服务器和客户端程序的基本信息。
Modbus TCP是一种基于TCP/IP协议的Modbus通信协议,可用于在计算机网络上实现Modbus通信。Modbus TCP服务器和客户端程序是用于实现Modbus TCP通信的程序。
服务器程序通常负责处理客户端请求,并向客户端提供所需的数据。客户端程序则向服务器发送请求,并从服务器获取数据。
C语言是一种常用的编程语言,可用于编写Modbus TCP服务器和客户端程序。在编写这些程序时,需要使用一些网络编程库,如socket库、libmodbus库等。
以下是一个简单的Modbus TCP服务器程序的示例:
```c
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <sys/socket.h>
#include <netinet/in.h>
#include <arpa/inet.h>
#include <errno.h>
#include <unistd.h>
#include <modbus.h>
#define SERVER_PORT 502
int main(int argc, char *argv[])
{
modbus_t *ctx;
uint8_t *query;
int sockfd, clientfd, rc;
struct sockaddr_in servaddr, clientaddr;
socklen_t clientlen = sizeof(clientaddr);
// 创建Modbus上下文
ctx = modbus_new_tcp("127.0.0.1", SERVER_PORT);
if (ctx == NULL) {
fprintf(stderr, "Error: unable to create Modbus context\n");
return EXIT_FAILURE;
}
// 初始化Modbus服务器
modbus_set_debug(ctx, TRUE);
modbus_set_slave(ctx, 1);
modbus_set_response_timeout(ctx, 1, 0);
modbus_set_error_recovery(ctx, MODBUS_ERROR_RECOVERY_LINK);
// 创建TCP监听套接字
sockfd = socket(AF_INET, SOCK_STREAM, 0);
if (sockfd < 0) {
fprintf(stderr, "Error: unable to create socket\n");
return EXIT_FAILURE;
}
// 绑定TCP监听套接字到本地IP地址和端口号
memset(&servaddr, 0, sizeof(servaddr));
servaddr.sin_family = AF_INET;
servaddr.sin_addr.s_addr = htonl(INADDR_ANY);
servaddr.sin_port = htons(SERVER_PORT);
if (bind(sockfd, (struct sockaddr *)&servaddr, sizeof(servaddr)) < 0) {
fprintf(stderr, "Error: unable to bind socket\n");
return EXIT_FAILURE;
}
// 开始监听TCP连接请求
if (listen(sockfd, 5) < 0) {
fprintf(stderr, "Error: unable to listen socket\n");
return EXIT_FAILURE;
}
// 接受TCP连接请求
clientfd = accept(sockfd, (struct sockaddr *)&clientaddr, &clientlen);
if (clientfd < 0) {
fprintf(stderr, "Error: unable to accept socket\n");
return EXIT_FAILURE;
}
// 处理Modbus请求
query = malloc(MODBUS_TCP_MAX_ADU_LENGTH);
while (1) {
rc = modbus_receive(ctx, query);
if (rc > 0) {
modbus_reply(ctx, query, rc, NULL);
} else if (rc == -1 && errno != EINTR) {
break;
}
}
// 关闭TCP连接
close(clientfd);
close(sockfd);
// 销毁Modbus上下文
modbus_free(ctx);
return EXIT_SUCCESS;
}
```
以下是一个简单的Modbus TCP客户端程序的示例:
```c
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <sys/socket.h>
#include <netinet/in.h>
#include <arpa/inet.h>
#include <errno.h>
#include <unistd.h>
#include <modbus.h>
#define SERVER_ADDR "127.0.0.1"
#define SERVER_PORT 502
int main(int argc, char *argv[])
{
modbus_t *ctx;
uint16_t *tab_reg;
int sockfd, rc;
// 创建Modbus上下文
ctx = modbus_new_tcp(SERVER_ADDR, SERVER_PORT);
if (ctx == NULL) {
fprintf(stderr, "Error: unable to create Modbus context\n");
return EXIT_FAILURE;
}
// 连接到Modbus服务器
if (modbus_connect(ctx) < 0) {
fprintf(stderr, "Error: unable to connect to Modbus server\n");
modbus_free(ctx);
return EXIT_FAILURE;
}
// 读取Modbus寄存器
tab_reg = malloc(2 * sizeof(uint16_t));
rc = modbus_read_registers(ctx, 0, 2, tab_reg);
if (rc < 0) {
fprintf(stderr, "Error: unable to read Modbus registers\n");
modbus_free(ctx);
return EXIT_FAILURE;
}
// 输出Modbus寄存器的值
printf("Register 0 = %d\n", tab_reg[0]);
printf("Register 1 = %d\n", tab_reg[1]);
// 关闭TCP连接
modbus_close(ctx);
modbus_free(ctx);
return EXIT_SUCCESS;
}
```
阅读全文