如何在 NiFi 中调用远程 REST 服务
How to invoke a remote REST service in NiFi
是否可以在NIFI处理器中使用xmlHttpRequest来调用远程rest服务?在我的例子中,ExecuteScript
处理器(使用 Javascript)无法评估 XMLHttpRequest
;有没有类似的解决方案可以用来获取响应数据?
var OutputStreamCallback = Java.type("org.apache.nifi.processor.io.OutputStreamCallback");
var StandardCharsets = Java.type("java.nio.charset.StandardCharsets");
Date.prototype.isValid = function () {
return (Object.prototype.toString.call(this) === "[object Date]")
&& !isNaN(this.getTime());
};
var flowFile = session.get();
if (flowFile != null) {
var fromDate = flowFile.getAttribute('fromDate')
var uid = flowFile.getAttribute('uid')
var xmlhttp = null;
var result = null;
xmlhttp = new XMLHttpRequest();
if (typeof xmlhttp.overrideMimeType != 'undefined') {
xmlhttp.overrideMimeType('application/json');
} else if (window.ActiveXObject) {
xmlhttp = new ActiveXObject("Microsoft.XMLHTTP");
}
xmlhttp.open('GET', "similar url here WorkInfo?dateFrom=?&uid=?", true);
xmlhttp.send(dateFrom, uid);
if (xmlhttp.status == 200) {
result = 'WorkInfoDate'
}
flowFile = session.putAttribute(flowFile, 'filename', fromDate + '_' + result);
flowFile = session.write(flowFile,
new OutputStreamCallback(function (outputStream) {
outputStream.write(command.getBytes(StandardCharsets.UTF_8))
}));
session.transfer(flowFile, REL_SUCCESS)
}
有一个 InvokeHttp 处理器可以用来调用 REST 服务而无需编写任何代码:
服务的响应将写入流文件的内容。
是否可以在NIFI处理器中使用xmlHttpRequest来调用远程rest服务?在我的例子中,ExecuteScript
处理器(使用 Javascript)无法评估 XMLHttpRequest
;有没有类似的解决方案可以用来获取响应数据?
var OutputStreamCallback = Java.type("org.apache.nifi.processor.io.OutputStreamCallback");
var StandardCharsets = Java.type("java.nio.charset.StandardCharsets");
Date.prototype.isValid = function () {
return (Object.prototype.toString.call(this) === "[object Date]")
&& !isNaN(this.getTime());
};
var flowFile = session.get();
if (flowFile != null) {
var fromDate = flowFile.getAttribute('fromDate')
var uid = flowFile.getAttribute('uid')
var xmlhttp = null;
var result = null;
xmlhttp = new XMLHttpRequest();
if (typeof xmlhttp.overrideMimeType != 'undefined') {
xmlhttp.overrideMimeType('application/json');
} else if (window.ActiveXObject) {
xmlhttp = new ActiveXObject("Microsoft.XMLHTTP");
}
xmlhttp.open('GET', "similar url here WorkInfo?dateFrom=?&uid=?", true);
xmlhttp.send(dateFrom, uid);
if (xmlhttp.status == 200) {
result = 'WorkInfoDate'
}
flowFile = session.putAttribute(flowFile, 'filename', fromDate + '_' + result);
flowFile = session.write(flowFile,
new OutputStreamCallback(function (outputStream) {
outputStream.write(command.getBytes(StandardCharsets.UTF_8))
}));
session.transfer(flowFile, REL_SUCCESS)
}
有一个 InvokeHttp 处理器可以用来调用 REST 服务而无需编写任何代码:
服务的响应将写入流文件的内容。