在Visual Studio的Logic App Designer中选择现有连接时,为什么要在JSON文件中添加新连接?

时间:2019-02-11 08:55:12

标签: visual-studio-2017 azure-logic-apps

我找不到有关此行为的任何文章。

我正在使用Visual Studio 2017和Logic App Designer。我有一个使用参数文件在部署时可以完美工作的配置。当我在设计器中打开JSON时,它显示“ 无效的连接”,并且可以选择现有连接或新连接。如果我选择现有的,则该操作将再次启用并可以在工作室中使用。

但是另一方面,在JSON文件中,创建了一个新连接,该连接与先前的连接完全相同,但是在本例中,该连接被称为sftp_2-操作正在使用该连接。我试图更改对旧连接的所有引用,但它不起作用-它给了我同样的错误。

它在我星期五离开工作时起作用,但是在我今天重新打开Visual Studio之后没有起作用。我是否需要先以某种方式激活/重新打开旧连接?

连接看起来像这样:

{
  "type": "MICROSOFT.WEB/CONNECTIONS",
  "apiVersion": "2016-06-01",
  "name": "[parameters('sftp_1_Connection_Name')]",
  "location": "[parameters('logicAppLocation')]",
  "properties": {
    "api": {
      "id": "[concat(subscription().id, '/providers/Microsoft.Web/locations/', parameters('logicAppLocation'), '/managedApis/', 'sftp')]"
    },
    "displayName": "[parameters('sftp_1_Connection_DisplayName')]",
    "parameterValues": {
      "hostName": "[parameters('sftp_1_hostName')]",
      "userName": "[parameters('sftp_1_userName')]",
      "password": "[parameters('sftp_1_password')]",
      "sshPrivateKey": "[parameters('sftp_1_sshPrivateKey')]",
      "sshPrivateKeyPassphrase": "[parameters('sftp_1_sshPrivateKeyPassphrase')]",
      "portNumber": "[parameters('sftp_1_portNumber')]",
      "giveUpSecurityAndAcceptAnySshHostKey": "[parameters('sftp_1_giveUpSecurityAndAcceptAnySshHostKey')]",
      "sshHostKeyFingerprint": "[parameters('sftp_1_sshHostKeyFingerprint')]",
      "disableUploadFilesResumeCapability": "[parameters('sftp_1_disableUploadFilesResumeCapability')]"
    }
  }
},

这是动作之一:

"Get_file_content": {
                      "type": "ApiConnection",
                      "inputs": {
                        "host": {
                          "connection": {
                            "name": "@parameters('$connections')['sftp_1']['connectionId']"
                          }
                        },
                        "method": "get",
                        "path": "/datasets/default/files/@{encodeURIComponent(encodeURIComponent(parameters('sftp_1_filepath'),items('For_each')?['Name']))}/content",
                        "queries": {
                          "inferContentType": true
                        }
                      },
                      "runAfter": {}
                    }

最后是连接数组:

"$connections": {
        "value": {
          "sftp_1": {
            "id": "[concat(subscription().id, '/providers/Microsoft.Web/locations/', parameters('logicAppLocation'), '/managedApis/', 'sftp')]",
            "connectionId": "[resourceId('Microsoft.Web/connections', parameters('sftp_1_Connection_Name'))]",
            "connectionName": "[parameters('sftp_1_Connection_Name')]"
          },
          "filesystem": {
            "id": "[concat(subscription().id, '/providers/Microsoft.Web/locations/', parameters('logicAppLocation'), '/managedApis/', 'filesystem')]",
            "connectionId": "[resourceId('Microsoft.Web/connections', parameters('filesystem_1_Connection_Name'))]",
            "connectionName": "[parameters('filesystem_1_Connection_Name')]"
          }
        }
      }

这是逻辑应用程序流程 https://i.imgur.com/UIitHNP.png

1 个答案:

答案 0 :(得分:2)

其背后的原因是Visual Studio Logic Apps Designer不会检查此连接器使用的此连接是否在逻辑应用程序或Azure中的其他位置使用。因此,在这种情况下,现在较旧的API连接仍在Azure某个地方使用,而是创建了一个额外的API连接(在本例中为sftp_2)。

设计器可帮助您发现“动态内容”。但是,为此,即使在开发阶段而不是在部署阶段,也需要创建API连接。

作为覆盖,Visual Studio Designer中的此连接意味着保存后将在Azure中覆盖。由于在Visual Studio中工作时,您已经在使用Azure中部署的对象(例如连接)。

如果发生这种情况,我通常会使用Ctrl + H并替换旧名称的新连接,并删除旧名称的任何引用-繁琐的工作。

关于l --''''''---------''''''''''''问题,这变成了鸡蛋和母鸡的问题。您正在尝试设置命名约定,但是如果由设计人员进行更改,则会在设置命名约定之前创建API连接。如果您在JSON中工作,则可以对参数进行处理,但设计器看起来好像坏了。可以构建该参数,以便仅修改连接名称。

这里的连接器名为blob-3221,但我必须将参数命名为CustomVariableNameCustomName。我突出显示了“自定义”出现在代码中的位置。所以在这里它说azureblob_1_Connection_Name为blob-3221,显示名称为blob-test

Deployment Parameters

这是已声明但未使用的两个值:

Parameters in arm

在部署时,它将获得以下值: Working Logic App connection

诸如blob-3221之类的占位符值被删除,并且自定义前缀名称被注入。 Created connections

无前缀名称的参数文件。 Parameter file for name