我的 JSON Slack Message 负载输出有什么问题?

What is wrong with my JSON output for a Slack Message payload?

我已经设置了我认为应该有效的 JSON 输出以在 slack 中发送消息,但 Slack 一直拒绝它。

我已经使用 slack 的 api 网站上的指南尝试了多种不同的消息布局格式,但到目前为止,唯一成功发送的方法是完全扁平的 JSON,没有块格式。

function submitValuesToSlack(e) {

  var name = e.values[1];
  var caseNumber = e.values[2];
  var problemDescription = e.values[3];
  var question = e.values[4];
  var completedChecklist = e.values[5];

  var payload = [{
    "channel": postChannel,
    "username": postUser,
    "icon_emoji": postIcon,
    "link_names": 1,
    "blocks": [
      {
        "type": "section",
        "fields": [
          {
            "type": "mrkdwn",
            "text": "*Name:*\n " + name
          }
        ]
      }]
  }];
  console.log(JSON.stringify(payload, null, "\t"));

  var options = {
    'method': 'post',
    'payload': JSON.stringify(payload)
  };

  console.log(options)

  var response = UrlFetchApp.fetch(slackIncomingWebhookUrl, options);

}

当我运行这个时,我得到以下输出:

[  
   {  
      "channel":"#tech-support",
      "username":"Form Response",
      "icon_emoji":":mailbox_with_mail:",
      "link_names":1,
      "blocks":[  
         {  
            "type":"section",
            "fields":[  
               {  
                  "type":"mrkdwn",
                  "text":"*Name:*\n test"
               }
            ]
         }
      ]
   }
]

我认为这是正确的,但是 slack api 只是拒绝它并出现 HTTP 400 错误 "no text"

我对块格式有什么误解吗?

编辑:

澄清一下,如果我将其用于我的 JSON 而不是更复杂的格式:

{  
      "channel":"#tech-support",
      "username":"Form Response",
      "icon_emoji":":mailbox_with_mail:",
      "link_names":1,
      "text":"*Name:*\n test"
}

您收到错误 no_text 的原因是您的负载中没有有效的消息文本 属性。您需要将文本 属性 作为顶行参数(经典样式 - 您的示例位于底部)或部分块中的文本块。

如果您只想使用块(如您所问),则该部分块称为 text,而不是 fieldsfields 是另一种具有不同含义的节块。

所以正确的语法是:

[  
   {  
      "channel":"#tech-support",
      "username":"Form Response",
      "icon_emoji":":mailbox_with_mail:",
      "link_names":1,
      "blocks":[  
         {  
            "type":"section",
            "text":[  
               {  
                  "type":"mrkdwn",
                  "text":"*Name:*\n test"
               }
            ]
         }
      ]
   }
]

另见 here 官方文档。

块非常强大,但有时会很复杂。我建议使用消息生成器来测试您的消息并查看文档中的示例。