Я использую конвейер Streamsets для потоковой передачи данных из браузеров. Поэтому для этого я создал конвейер с источником HTTP-сервера для отправки данных из браузеров Javascript и попытался записать этот URL-адрес с помощью клиента REST, и он успешно пишет. Заголовки ответов уже заданы в файле SDC.properties.
http.access.control.allow.origin=*
http.access.control.allow.headers=origin, content-type, accept, authorization, x-requested-by, x-ss-user-auth-token, x-ss-rest-call
http.access.control.allow.methods=GET, POST, PUT, DELETE, OPTIONS, HEAD
Но когда я пытаюсь записать некоторые данные из JavaScript с помощью XMLHTTPRequest, возникает ошибка для предварительного запроса. Ниже приведен код JavaScript:
var http = new XMLHttpRequest();
var value = '{ "prop1": "value 2", "prop2": "value 2" }';
var url ='http://13.68.93.97:8100/'
var async = true
if ('withCredentials' in http) {
http.open('OPTIONS', url, async);
} else if (typeof XDomainRequest != "undefined") {
http = new XDomainRequest(); //for IE
http.open('OPTIONS', url);
} else {
http.open('OPTIONS', url, async);
}
http.open('POST', url, true);
http.setRequestHeader('Content-Type', 'application/json; charset=utf-8');
http.setRequestHeader('X-SDC-APPLICATION-ID', 'testApp1');
http.setRequestHeader("Access-Control-Allow-Origin", "*");
http.setRequestHeader('Access-Control-Allow-Methods', "POST, OPTIONS, GET");
http.setRequestHeader('Access-Control-Allow-Credentials', "true");
http.setRequestHeader('Access-Control-Expose-Headers', "X-Region");
http.setRequestHeader("Access-Control-Allow-Headers", "Origin, X-Requested-With, Content-Type, Accept,Accept-language");
http.withCredentials = true;
http.onreadystatechange = function () {
if (http.readyState == 4 && http.status == 200) {
console.log(http.responseText);
}
}
http.send(value);
Ошибка, вызванная выполнением вышеуказанного кода:
XMLHttpRequest не может загрузить http://13.68.93.97:8100/. Ответ на предварительный запрос не проходит проверку управления доступом: в запрошенном ресурсе отсутствует заголовок «Access-Control-Allow-Origin». Таким образом, доступ к источнику 'http://localhost' запрещен.
Любая помощь будет действительно полезной. Спасибо..!!