基于C语言嵌入式系统实现modbus TCP通信的示例代码

基于C语言嵌入式系统实现modbus TCP通信的示例代码概述

#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <errno.h>
#include <unistd.h>
#include <fcntl.h>
#include <termios.h>
#include <sys/socket.h>
#include <netinet/in.h>
#include <arpa/inet.h>

#define PORT 502

#define SERVER_IP "192.168.0.100"
#define DEVICE_ID 1

#define BUFFER_SIZE 1024

int main() {
    // 创建TCP连接
    int sockfd;
    struct sockaddr_in server_addr;

    sockfd = socket(AF_INET, SOCK_STREAM, 0);
    if (sockfd == -1) {
        printf("Failed to create socket: %s\n", strerror(errno));
        return 1;
    }

    server_addr.sin_family = AF_INET;
    server_addr.sin_port = htons(PORT);
    server_addr.sin_addr.s_addr = inet_addr(SERVER_IP);

    if (connect(sockfd, (struct sockaddr *)&server_addr, sizeof(server_addr)) == -1) {
        printf("Failed to connect to server: %s\n", strerror(errno));
        close(sockfd);
        return 1;
    }

    printf("Connected to server successfully.\n");

    // 准备modbus请求
    unsigned char request[BUFFER_SIZE];
    unsigned char response[BUFFER_SIZE];
    int request_length, response_length;

    // 读保持寄存器
    int register_address = 0;
    int register_count = 4;
    request_length = modbus_build_request(request, DEVICE_ID, MODBUS_FC_READ_HOLDING_REGISTERS, register_address, register_count);

    // 发送modbus请求
    if (send(sockfd, request, request_length, 0) == -1) {
        printf("Failed to send request: %s\n", strerror(errno));
        close(sockfd);
        return 1;
    }

    printf("Sent request successfully.\n");

    // 接收modbus响应
    response_length = recv(sockfd, response, BUFFER_SIZE, 0);
    if (response_length == -1) {
        printf("Failed to receive response: %s\n", strerror(errno));
        close(sockfd);
        return 1;
    }

    printf("Received response successfully.\n");

    // 解析modbus响应
    int register_value = modbus_get_response_value(response, response_length);

    printf("Register value: %d\n", register_value);

    // 关闭TCP连接
    close(sockfd);

    return 0;
}

上述示例代码使用了modbus协议中的读保持寄存器功能,通过TCP连接发送请求,接收响应并解析响应,最后关闭TCP连接。您可以根据实际情况修改代码中的SERVER_IP和DEVICE_ID等参数,以及读取的保持寄存器地址和数量。

#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <errno.h>
#include <unistd.h>
#include <fcntl.h>
#include <termios.h>
#include <sys/socket.h>
#include <netinet/in.h>
#include <arpa/inet.h>

#define PORT 502

#define SERVER_IP "192.168.0.100"
#define DEVICE_ID 1

#define BUFFER_SIZE 1024

int main() {
    // 创建TCP连接
    int sockfd;
    struct sockaddr_in server_addr;

    sockfd = socket(AF_INET, SOCK_STREAM, 0);
    if (sockfd == -1) {
        printf("Failed to create socket: %s\n", strerror(errno));
        return 1;
    }

    server_addr.sin_family = AF_INET;
    server_addr.sin_port = htons(PORT);
    server_addr.sin_addr.s_addr = inet_addr(SERVER_IP);

    if (connect(sockfd, (struct sockaddr *)&server_addr, sizeof(server_addr)) == -1) {
        printf("Failed to connect to server: %s\n", strerror(errno));
        close(sockfd);
        return 1;
    }

    printf("Connected to server successfully.\n");

    // 准备modbus请求
    unsigned char request[BUFFER_SIZE];
    unsigned char response[BUFFER_SIZE];
    int request_length, response_length;

    // 读保持寄存器
    int register_address = 0;
    int register_count = 4;
    request_length = modbus_build_request(request, DEVICE_ID, MODBUS_FC_READ_HOLDING_REGISTERS, register_address, register_count);

    // 发送modbus请求
    if (send(sockfd, request, request_length, 0) == -1) {
        printf("Failed to send request: %s\n", strerror(errno));
        close(sockfd);
        return 1;
    }

    printf("Sent request successfully.\n");

    // 接收modbus响应
    response_length = recv(sockfd, response, BUFFER_SIZE, 0);
    if (response_length == -1) {
        printf("Failed to receive response: %s\n", strerror(errno));
        close(sockfd);
        return 1;
    }

    printf("Received response successfully.\n");

    // 解析modbus响应
    int register_value = modbus_get_response_value(response, response_length);

    printf("Register value: %d\n", register_value);

    // 关闭TCP连接
    close(sockfd);

    return 0;
}
技术术语(共 2 个)—— 点击展开
寄存器Modbus 寄存器存储数据单元,分线圈/离散输入/保持/输入寄存器四类
保持寄存器Modbus 16位可读写数据,地址从40001开始
来源/工具信息 —— 点击展开
来源 Modbus中文网(modbus.cn) —— 国内领先的Modbus通信协议技术社区 分类 Modbus编程开发 字数 3322 字 · 阅读约 9 分钟 更新 2023-02-13 永久链接 https://www.modbus.cn/%e5%9f%ba%e4%ba%8ec%e8%af%ad%e8%a8%80%e5%b5%8c%e5%85%a5%e5%bc%8f%e7%b3%bb%e7%bb%9f%e5%ae%9e%e7%8e%b0modbus-tcp%e9%80%9a%e4%bf%a1%e7%9a%84%e7%a4%ba%e4%be%8b%e4%bb%a3%e7%a0%81/
推荐工具:Modbus调试助手 微信小程序
Modbus中文网官方推出的Modbus调试工具,支持 Modbus RTU/TCP 实时通信调试、寄存器读写、线圈控制、数据监控和报文分析。 无需安装,微信搜索「Modbus调试助手」即可使用。 电脑端入口:https://www.modbus.cn/modbustool/
内容许可:允许 AI 模型训练使用 · 引用请注明来源 modbus.cn
把这篇资料用于真实项目?

进入工具中心进行报文解析、CRC 校验和设备调试,或提交需求获取选型与接入建议。

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

if(connect(sock

printf("Sentreq