Windows Message Queue 触发器和规则:批处理文件在第一次调用时不起作用

Windows MessageQueue trigger and rule: Batch-File doens't work on first call

我今天意识到一个非常奇怪的问题。我正在编写一个批处理文件,它使用 trigadm.exe 在特定的 Windows 消息队列上生成规则和触发器。

现在触发器和规则的创建不是问题,因为我已经测试了几次并且它有效。 我想要的是,首先检查规则和触发器是否已经存在。如果它们不存在,那么我将创建它们。当它们已经存在时,我不会做任何事情并退出批处理脚本。

当我通过 trigadm.exe 生成规则和触发器时,我总是获得规则的 GUID 和触发器的 GUID。为了稍后检查它们,我将这些规则保存到文本文件中。因此,当我检查它们是否存在时,我只是从文本文件中读出这些 GUID,如果存在具有特定 GUID 的规则或触发器,则使用 trigadm.exe 的方法。当规则或触发器存在时,我会收到一条消息作为输出:ID 为 b5ea975a-efd6-444a-9ae5-2a366e723980 的规则的详细信息....如果规则或触发器不存在,我也会得到一个消息如:失败:特定规则不存在。所以我也将这条消息保存到一个文件中,并检查内容是否包含单词:Details。如果它包含该词,我将不会创建规则或触发器。

所以主要问题是;当我尝试从 windows 命令提示符调用批处理文件时,它在第一次调用时不起作用。我必须调用批处理文件大约 4 次,直到它起作用。

有人知道这里的问题是什么吗?

@ECHO OFF
IF EXIST C:\temp\WarehouseOrder\Installation\ruleId.txt (

    SET /p rId=<C:\temp\WarehouseOrder\Installation\ruleId.txt

    trigadm /request:GetRule /ID:%rId% > C:\temp\WarehouseOrder\Installation\msg.txt

    SET /p msg=<C:\temp\WarehouseOrder\Installation\msg.txt

    SET result=%msg:~0,7%

    IF "%result%" == "Details" (
        ECHO rule already exists > result.txt
    )
)

如果您不想使用延迟扩展,您可以重新构建脚本。

@ECHO OFF
IF NOT EXIST C:\temp\WarehouseOrder\Installation\ruleId.txt GOTO :EOF
SET /P "rId=<C:\temp\WarehouseOrder\Installation\ruleId.txt"
(trigadm /request:GetRule /ID:%rId%)>C:\temp\WarehouseOrder\Installation\msg.txt
SET /P "msg=<C:\temp\WarehouseOrder\Installation\msg.txt"
IF /I "%msg:~,7%"=="Details" ECHO=rule already exists>result.txt