У меня есть серверная часть Node.js, которую я использую для аутентификации и для обратного прокси-сервера веб-интерфейса ArangoDB.Я не могу понять, почему я не могу войти в веб-интерфейс, используя мой внешний URL-адрес.
Я искал высокий и низкий уровень (Google, переполнение стека, потоки arangodb git, потоки кода приложения arangodb)и т. д.), и не могу понять это.Я не обязан использовать модуль node-http-proxy, который я использую ниже.Если кто-то сделал это внутри узла другим способом.
Я видел примеры использования nginx и т. Д., Но я действительно стараюсь держать все под внутренним узлом узла, чтобы иметь возможность прокси-доступа за моим сайтомаутентификации, поэтому я не открываю веб-интерфейс для произвольного доступа.
Я надеюсь, что кто-то, кто преодолел это препятствие, может помочь.
Проблема: На запрос _open / auth никогда не отвечает.Я все еще могу получить доступ к http://localhost:8529 с сервера и войти в систему просто отлично.
Желаемый результат: получить доступ к веб-интерфейсу из http://example.com:8080/_db/_system/_admin/aardvark/index.html#login и успешно войти в систему.
[ChromeСведения о сети заголовков]:
Request URL: http://example.com:8080/_db/_system/_open/auth
Referrer Policy: no-referrer-when-downgrade
Request Headers:
Provisional headers are shown
Accept: application/json, text/javascript, */*; q=0.01
Authorization: bearer null
Content-Type: application/x-www-form-urlencoded; charset=UTF-8
Origin: http://example.com:8080
Referer: http://example.com:8080/_db/_system/_admin/aardvark/index.html
User-Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/73.0.3683.86 Safari/537.36
X-Requested-With: XMLHttpRequest
Form Data:
{"username":"username","password":"password"}:
Интересно: http://127.0.0.1:8080/_db/_system/_admin/aardvark/foxxes/fishbowl всегда выдает ошибку 401 (даже на сервере с адресом и портом локального хоста, думаю, что это ошибка в aardvark.js)
См. Ниже файлы конфигурации.
[rout.js]:
// =====================================
// ArangoDB Web interface ============
// =====================================
var httpProxy = require('http-proxy');
var proxy = httpProxy.createProxyServer({followRedirects: true});
// set headers location overwrite per arangodb documentation
proxy.on('proxyReq', function(proxyReq, req, res, options) {
proxyReq.setHeader('X-Script-Name', 'http://example.com:8080');
});
proxy.on('error', function(e) {
console.log(e);
});
app.all('*/_db/*', function(req, res) {
proxy.web(req, res, {target: 'http://localhost:8529'});
});
[/ etc / arangodb3 / arangod.conf]:
[frontend]
proxy-request-check=false
version-check=false
[http]
trusted-origin=all
allow-method-override=true
Примечание: я также попытался использовать пункт «поверенный-источник = *» (не уверен, какой из них правильный)