私.Modbus测试_ZC01_TCP方式

ZC:这个例子是使用TCP来交互midbus协议数据,我在这个例子里面没有查找到 dll或so文件,运行过程中也没有提示需要dll或so文件  也没有说缺少函数之类的,应该是 没有用到 dll或so文件的。

 

ZC:这是使用 TCP的方式来传输 modbus协议数据包的,想追一下源码 看看到底是不是 socket,追到 ModbusMaster.class的 调用函数sendImpl(...)就追不下去了。后一想 通过Debug来追,就来到了 TcpMaster.class中 在函数openConnection(...)中 可以看到 transport就是 socket的输入输出流,继续跟下去 在下面的 发送过程中 调用到了“transport.write(data);”  其实就是 使用socket在发送数据

 

1、modbus tcp通讯modbus4j使用说明-java编程-Leftso(左搜).html(http://www.leftso.com/blog/83.html

2、我的测试代码:

 2.1、包:(1)源码:"...\ZC_IDE\Java_3rd\modbus_java\03_最新的(20181125)\modbus4j-master.zip",(2)jar:"...\ZC_IDE\Java_3rd\modbus_java\02_新一点的\Mango Automation\m2m2-modbus-1.8.0.zip"的lib文件夹中有

  测试工具:ModbusSlave:"...\ZC__Self\私\ModbusSlave\Modbus Tools\Modbus Slave\mbslave.exe"

 2.2、

package com.modbus4j303;

import com.serotonin.modbus4j.BatchRead;
import com.serotonin.modbus4j.BatchResults;
import com.serotonin.modbus4j.ModbusFactory;
import com.serotonin.modbus4j.ModbusMaster;
import com.serotonin.modbus4j.code.DataType;
import com.serotonin.modbus4j.exception.ErrorResponseException;
import com.serotonin.modbus4j.exception.ModbusInitException;
import com.serotonin.modbus4j.exception.ModbusTransportException;
import com.serotonin.modbus4j.ip.IpParameters;
import com.serotonin.modbus4j.locator.BaseLocator;

public class Modbus4jUtils
{
    /**
     * 工厂。
     */
    static ModbusFactory modbusFactory;
    static {
        if (modbusFactory == null) {
            modbusFactory = new ModbusFactory();
        }
    }

    /**
     * 获取master
     * 
     * @return
     * @throws ModbusInitException
     */
    public static ModbusMaster getMaster() throws ModbusInitException {
        IpParameters params = new IpParameters();
        params.setHost("localhost");
        params.setPort(502);
        //
        // modbusFactory.createRtuMaster(wapper); //RTU 协议
        // modbusFactory.createUdpMaster(params);//UDP 协议
        // modbusFactory.createAsciiMaster(wrapper);//ASCII 协议
        ModbusMaster master = modbusFactory.createTcpMaster(params, false);// TCP 协议
        master.init();

        return master;
    }

    /**
     * 读取[01 Coil Status 0x]类型 开关数据 // ZC: Coil线圈
     * 
     * @param slaveId
     *            slaveId
     * @param offset
     *            位置
     * @return 读取值
     * @throws ModbusTransportException
     *             异常
     * @throws ErrorResponseException
     *             异常
     * @throws ModbusInitException
     *             异常
     */
    public static Boolean readCoilStatus(int slaveId, int offset)
            throws ModbusTransportException, ErrorResponseException, ModbusInitException {
        // 01 Coil Status
        BaseLocator<Boolean> loc = BaseLocator.coilStatus(slaveId, offset);
        Boolean value = getMaster().getValue(loc);
        return value;
    }

    /**
     * 读取[02 Input Status 1x]类型 开关数据
     * 
     * @param slaveId
     * @param offset
     * @return
     * @throws ModbusTransportException
     * @throws ErrorResponseException
     * @throws ModbusInitException
     */
    public static Boolean readInputStatus(int slaveId, int offset)
            throws ModbusTransportException, ErrorResponseException, ModbusInitException {
        // 02 Input Status
        BaseLocator<Boolean> loc = BaseLocator.inputStatus(slaveId, offset);
        Boolean value = getMaster().getValue(loc);
        return value;
    }

    /**
     * 读取[03 Holding Register类型 2x]模拟量数据
     * 
     * @param slaveId
     *            slave Id
     * @param offset
     *            位置
     * @param dataType
     *            数据类型,来自com.serotonin.modbus4j.code.DataType
     * @return
     * @throws ModbusTransportException
     *             异常
     * @throws ErrorResponseException
     *             异常
     * @throws ModbusInitException
     *             异常
     */
    public static Number readHoldingRegister(int slaveId, int offset, int dataType)
            throws ModbusTransportException, ErrorResponseException, ModbusInitException {
        // 03 Holding Register类型数据读取
        BaseLocator<Number> loc = BaseLocator.holdingRegister(slaveId, offset, dataType);
        Number value = getMaster().getValue(loc);
        return value;
    }

    /**
     * 读取[04 Input Registers 3x]类型 模拟量数据
     * 
     * @param slaveId
     *            slaveId
     * @param offset
     *            位置
     * @param dataType
     *            数据类型,来自com.serotonin.modbus4j.code.DataType
     * @return 返回结果
     * @throws ModbusTransportException
     *             异常
     * @throws ErrorResponseException
     *             异常
     * @throws ModbusInitException
     *             异常
     */
    public static Number readInputRegisters(int slaveId, int offset, int dataType)
            throws ModbusTransportException, ErrorResponseException, ModbusInitException {
        // 04 Input Registers类型数据读取
        BaseLocator<Number> loc = BaseLocator.inputRegister(slaveId, offset, dataType);
        Number value = getMaster().getValue(loc);
        return value;
    }

    /**
     * 批量读取使用方法
     * 
     * @throws ModbusTransportException
     * @throws ErrorResponseException
     * @throws ModbusInitException
     */
    public static void batchRead() throws ModbusTransportException, ErrorResponseException, ModbusInitException {

        BatchRead<Integer> batch = new BatchRead<Integer>();

        batch.addLocator(0, BaseLocator.holdingRegister(1, 1, DataType.FOUR_BYTE_FLOAT));
        batch.addLocator(1, BaseLocator.inputStatus(1, 0));

        ModbusMaster master = getMaster();

        batch.setContiguousRequests(false);
        BatchResults<Integer> results = master.send(batch);
        System.out.println(results.getValue(0));
        System.out.println(results.getValue(1));
    }

    /**
     * 测试
     * 
     * @param args
     */
    public static void main(String[] args)
    {
        try {
            // 01测试
            Boolean v011 = readCoilStatus(1, 0);
            Boolean v012 = readCoilStatus(1, 1);
            Boolean v013 = readCoilStatus(1, 6);
            System.out.println("v011:" + v011);
            System.out.println("v012:" + v012);
            System.out.println("v013:" + v013);
            // 02测试
            Boolean v021 = readInputStatus(1, 0);
            Boolean v022 = readInputStatus(1, 1);
            Boolean v023 = readInputStatus(1, 2);
            System.out.println("v021:" + v021);
            System.out.println("v022:" + v022);
            System.out.println("v023:" + v023);

            // 03测试
            Number v031 = readHoldingRegister(1, 1, DataType.FOUR_BYTE_FLOAT);// 注意,float
            Number v032 = readHoldingRegister(1, 3, DataType.FOUR_BYTE_FLOAT);// 同上
            System.out.println("v031:" + v031);
            System.out.println("v032:" + v032);

            // 04测试
            Number v041 = readInputRegisters(1, 1, DataType.FOUR_BYTE_FLOAT);//
            Number v042 = readInputRegisters(1, 3, DataType.FOUR_BYTE_FLOAT);//
            System.out.println("v041:" + v041);
            System.out.println("v042:" + v042);
            // 批量读取
            batchRead();

        } catch (Exception e) {
            e.printStackTrace();
        }
    }
}

 

3、

4、

5、

 

转载于:https://www.cnblogs.com/codeskilla/p/10016127.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Modbus 主站测试软件 这是一个小巧的Modbus Master测试工具,综合了Modbus TCPModbus UDP、Modbus RTU、Modbus ASCII 四种工作模式.是现场通讯测试的最佳助手。适合运行在任何Windows平台下。无需任何运行库。软件不需要安装,解压后可直接运行。 #### 功能简介 1. 选定连接方式为 以太网TCP、以太网UDP、串口RTU、串口ASCII 2. 如果是串口RTU、ASCII:设定串口客户端串口及参数,点击打开,可选择不同的寄存器进行读写操作。 如果是TCP、UDP:设定客户端IP和端口(默认502),点击连接,连接成功后,可选择不同的寄存器进行读写操作。 3. 该软件作为Modbus 主站(即Mdobus 客户端)使用,可以读取线圈寄存器(Output Coil)、离散输入寄存器(Input Relay)、保持寄存器(Holding Register)、输入寄存器(Input Register)的数据,同时可以写入线圈寄存器(Output Coil)、保持寄存器(Holding Register)数据;数据可以按格式格式进行显示,为测试工作带来便利。 #### 最后更新 v.5.1.12.46(Build 2020/12/11) - 双击快速修改线圈寄存器(Output Coil) - 线圈寄存器(Output Coil)添加HEX,BIN格式输入 v.5.0.0.42(Build 2020/12/03) - 新增收发时间显示,及时间格式 - 新增收发数据显示不同颜色 - 新增数据保存功能 - 修订线圈寄存器、离散输入寄存器数据显示 - 新增0FH功能码功能 - 完善各功能码反馈提示信息及异常信息 - 新增本地端口参数 - 完善各种数据换位格式,可选择以下显示方式 - 1: Signed (2 Byte)有符号整数(AB)* - 2: Signed (2 Byte)有符号整数(BA) - 3: UnSigned(2 Byte)无符号整数(AB)* - 4: UnSigned(2 Byte)无符号整数(BA) - 5: LongWord (4 Byte)无符号整数(AB CD)* - 6: LongWord (4 Byte)无符号整数(CD AB) - 7: LongWord (4 Byte)无符号整数(BA DC) - 8: LongWord (4 Byte)无符号整数(DC BA) - 9: LongInt (4 Byte)有符号整数(AB CD)* - 10: LongInt (4 Byte)有符号整数(CD AB) - 11: LongInt (4 Byte)有符号整数(BA DC) - 12: LongInt (4 Byte)有符号整数(DC BA) - 13: Float(4 Byte)单精度浮点(AB CD)* - 14: Float(4 Byte)单精度浮点(CD AB) - 15: Float(4 Byte)单精度浮点(BA DC) - 16: Float(4 Byte)单精度浮点(DC BA) - 17: Double(8 byte)双精度浮点(AB CD EF GH)* - 18: Double(8 byte)双精度浮点(GH EF CD AB) - 19: Double(8 byte)双精度浮点(BA DC FE HG) - 20: Double(8 byte)双精度浮点(HG FE DC BA) - 21: String 字符(AB) 包含以下功能码: - 01H--读取线圈寄存器(Output Coil),位操作,可读单个或者多个 - 02H--读取离散输入寄存器(Input Relay),位操作,可读单个或多个 - 03H--读保持寄存器(Holding Register),字节指令操作,可读单个或者多个 - 04H--读取输入寄存器(Input Register),字节指令操作,可读单个或者多个 - 05H-写单个线圈寄存器(Output Coil),位操作,只能写一个 - 06H--写单个保持寄存器(Holding Register),字节指令操作,只能写一个 - 0FH--写多个线圈寄存器(Output Coil),字节指令操作,可写多个 - 10H--写多个保持寄存器(Holding Register),字节指令操作,可写多个
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值