当前位置: 首页 > 面试题库 >

当请求com端口返回相同的请求时

徐柏
2023-03-14
问题内容

我正在尝试通过COM端口发送AT命令,但只重新发送了相同的命令。

package SerialConnections;

import jssc.SerialPort;
import jssc.SerialPortEvent;
import jssc.SerialPortEventListener;
import jssc.SerialPortException;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;

import static ru.telemetria.qa.utils.Utilities.waitTime;

public class M234Serial {
    private static Logger log = LoggerFactory.getLogger(M234Serial.class);
    private SerialPort serialPort;
    private byte[] receivedData;
    private boolean isReceived;

    public M234Serial() throws Exception {

        serialPort = new SerialPort("COM55");
    }

    public void sendCommand() throws Exception {
        open();

        String command = "AT^SCFG?";
        serialPort.writeBytes(command.getBytes());
        log.debug("Send request: " + command);

        while (!isReceived) {}

        close();
    }

    private void open() throws Exception {
        serialPort.openPort();
        serialPort.setParams(SerialPort.BAUDRATE_115200, SerialPort.DATABITS_8, SerialPort.STOPBITS_1, SerialPort.PARITY_NONE);
        serialPort.addEventListener(new SerialPortEventListener() {
            @Override
            public void serialEvent(SerialPortEvent serialPortEvent) {
                try {
                    waitTime(System.currentTimeMillis(), 2000);
                    receivedData = serialPort.readBytes();
                    log.debug("Received message: " + StringUtils.asciiToString(receivedData));
                    isReceived = true;
                    serialPort.removeEventListener();
                } catch (SerialPortException spe) {
                    spe.printStackTrace();
                }
            }
        });
    }

    private void close() throws Exception {
        serialPort.closePort();
    }

    public static void main(String[] args) throws Exception {
        log.debug("Create instance..");
        M234Serial serial = new M234Serial();
        serial.sendCommand();
        log.debug("End");
    }
}

日志:

16:19:21.910 [main]调试SerialConnections.M234Serial-创建实例。

16:19:21.974 [main]调试SerialConnections.M234Serial-发送请求:AT ^ SCFG?

16:19:23.976 [EventThread COM55]调试SerialConnections.M234Serial-收到的消息:AT ^
SCFG?

16:19:23.977 [main]调试SerialConnections.M234Serial-结束

我在做什么错,我该如何解决?


问题答案:

像这样的繁忙等待while (!isReceived) {}将产生可怕的性能,因此,如果保留该结构,则应将变量从布尔值更改为互斥量/信号量或类似的东西。但是您不应该保留它,因此我仅出于参考目的而提及它。

首先,获取V.250调制解调器标准的副本,并至少阅读第5章的全部内容。这将教给您许多基本的AT命令处理,例如AT命令行应以终止\r

AT ^
SCFG命令显然是专有的制造商特定命令,因此我没有文档参考。3GPP标准化的大多数与手机相关的AT命令在27.007中给出,尽管某些(与SMS相关)在27.005中给出

如开头所述,结构需要更改。你应该 永远,永远,永远,永远
使用waitTimesleep或任何类似的等待从调制解调器的响应。它就像踢狗挡在您的路上以让它们移动一样有用。是的,您可能很幸运,有时它确实可以工作,但是在某些时候,您会为采用这种方法感到遗憾…

唯一可靠的方法是执行类似于

serialPort.openPort();
...
// start sending AT^SCFG?
serialPort.writeBytes("AT^SCFG?\r");
do {
    line = readLine(serialPort);
} while (! is_final_result_code(line))
// Sending of AT^SCFG? command finished (successfully or not)
...
serialPort.closePort();

readLine函数从串行端口读取一个字节和一个字节,直到它接收到以结尾的完整行\r\n,然后返回该行。

你可以看一下代码为atinout针对的一个例子is_final_result_code功能(也可以比较isFinalResponseError,并isFinalResponseSuccess在ST-
Ericsson的U300
RIL,但请注意,CONNECT不是最终结果代码,它是一个中间结果码,故得名isFinalResponseSuccess是严格来说不是100%正确)。

命令发送被接收回的问题与调制解调器回显该命令有关。可以使用ATE命令禁用此功能,但是使用上述适当的解析结构通常并不重要,因为您只需将echoed命令读为将被忽略的行即可。



 类似资料:
  • 但当我的代码调用提供程序时,将foo作为任何文本,wiremock返回: 如何构建一个与请求体响应相同参数的契约? 编辑 也许不支持从请求获取正则表达式值?

  • 我已经使用zappa在aws lambda上部署了一个flask应用程序,现在该应用程序在所有endpoint上都运行良好,除了我的主endpoint,当我对其发出post请求时,它返回{“消息”:“endpoint请求超时”} 真的需要一个修复或想法如何克服这个我需要调用分析路线,部署的url是 https://2ixfyfcsik.execute-api.eu-west-2.amazonaws

  • 我必须做一个帖子,但我得到错误405 在本网站->http://177.66.89.34:8079/transparencia/#我需要迭代页面顶部的2个下拉菜单的选项。 首先,我会在“escolha o exercício”旁边加上选项:然后,我会在“escolha a entidade”旁边加上选项: 用下面的代码,我在“EscolhaoExercício:”上面写了一篇文章 我希望在pars

  • 我试图对我写的rest api执行一个put请求,但它总是返回400-bug请求。 java.io.IO异常:服务器返回HTTP响应代码:400为URL:http://localhost:8000/api/v0/contacts/2sun.net.www.protocol.http.HttpURLConnection.getInputStream(未知来源) 我可以用firefox rest客户端

  • 问题内容: 我正在使用promis模块从请求模块返回我的json数据,但是每次运行它时,它都会为我提供此信息。 我无法正常工作,有人知道这个问题吗?这是我的代码: 问题答案: 许诺是充当未来价值的占位符的对象。您的函数返回该Promise对象。通过将处理程序附加到promise,您可以在promise中获得未来的价值: 这是异步代码,因此,仅能通过处理程序来获得承诺的价值。 修改清单: 在返回的p

  • 我是SNMP新手,我正在尝试使用SNMP操作,我正在使用http://techdive.in/snmp/snmp4j-snmp-get-example代码,但我无法获得预期的输出。我得到如下空响应: SNMP获取演示正在向代理发送请求。。。从代理Snmp获取响应获取响应=[1.3.6.1.2.1.1.1.0=Null] 当我试图为MIB RFC 1213的OID获取sysDescr时,预期的输出应