我正在通过分页调用rest api,并在响应中以以下格式在HTTP标头中获得“下一个”链接:Link <https://aaaaaa/bbb/ccc/ddd/version/2.1.1/locations/?date_from=1601-01-01T00%3a00%3a00Z&date_to=2019-04-24T17%3a03%3a29Z&offset=100&limit=100
>; rel =“ next”
我可以轻松获取HTTP Header链接参数的值
但是,Azure Logic Apps中没有正则表达式,可用于进一步解析<和>
之间的部分中的链接值一种选择是编写一个处理此问题的Azure函数,但我正在寻找更简单的方法(如果可能)
{
"inputs": {
"name": "newLink",
"value": "@{outputs('HTTP')['headers']?['Link']}"
}
}
newLink变量现在包含link的完整值。 但是我只需要<和>
之间的部分任何关于如何将newLink变量解析为所需内容的提示(不使用Azure函数)都受到高度赞赏。
答案 0 :(得分:3)
您可以使用spilt()
函数,如下所示:
@split(split(triggerOutputs()['headers']?['Link'],'<')[1],'>')[0]
设计器视图
代码视图
{
"definition": {
"$schema": "https://schema.management.azure.com/providers/Microsoft.Logic/schemas/2016-06-01/workflowdefinition.json#",
"actions": {
"Response": {
"inputs": {
"body": "@split(split(triggerOutputs()['headers']?['Link'],'<')[1],'>')[0]",
"statusCode": 200
},
"kind": "Http",
"runAfter": {},
"type": "Response"
}
},
"contentVersion": "1.0.0.0",
"outputs": {},
"parameters": {},
"triggers": {
"manual": {
"inputs": {
"schema": {}
},
"kind": "Http",
"type": "Request"
}
}
}
}
邮差: