Другое решение состоит в том, чтобы выполнить код через последовательный исполнитель nsynjs .
nsynjs будет последовательно оценивать все обещания и ставить обещания результат в свойство data
:
function synchronousCode() {
var getURL = function(url) {
return window.fetch(url).data.text().data;
};
var url = 'https://ajax.googleapis.com/ajax/libs/jquery/2.0.0/jquery.min.js';
console.log('received bytes:',getURL(url).length);
};
nsynjs.run(synchronousCode,{},function(){
console.log('synchronousCode done');
});
Шаг 1. Wrap с обратным вызовом в оболочку, совместимую с nsynjs (если у нее есть обещанная версия, вы можете пропустить этот тест):
var ajaxGet = function (ctx,url) {
var res = {};
var ex;
$.ajax(url)
.done(function (data) {
res.data = data;
})
.fail(function(e) {
ex = e;
})
.always(function() {
ctx.resume(ex);
});
return res;
};
ajaxGet.nsynjsHasCallback = true;
Шаг 2. Вставить синхронную логику в функцию:
function process() {
console.log('got data:', ajaxGet(nsynjsCtx, "data/file1.json").data);
}
Шаг 3. Выполнить функцию синхронно через nnsynjs:
nsynjs.run(process,this,function () {
console.log("synchronous function finished");
});
Nsynjs будет оценивать все операторы и выражения шаг за шагом, приостанавливая выполнение в случае, если результат некоторой медленной функции не готов.
Дополнительные примеры здесь: https://github.com/amaksr/nsynjs/tree/master/examples
Использование реализации по умолчанию ClientHttpRequestFactory
- это SimpleClientHttpRequestFactory - поведение по умолчанию заключается в том, чтобы следовать URL-адресу заголовка местоположения (для ответов с кодами состояния 3xx
), но только если Первоначальный запрос был запросом GET
.
Подробности можно найти в этом классе - поиск следующего метода:
protected void prepareConnection(HttpURLConnection connection, String httpMethod) throws IOException {
...
if ("GET".equals(httpMethod)) {
connection.setInstanceFollowRedirects(true);
}
Здесь соответствующий комментарий к документу метода HttpURLConnection.setInstanceFollowRedirects
:
Устанавливает, следует ли автоматически перенаправлять HTTP (запросы с кодом ответа 3xx) с помощью этого экземпляра {@code HttpURLConnection}.
Значение по умолчанию происходит от followRedirects, значение по умолчанию равно true.
blockquote>
При использовании команды CommonsClientHttpRequestFactory (которая использует внизу HttpClient v3 ) вы можете переопределить метод postProcessCommonsHttpMethod и установить, чтобы следовать переадресации.
public class FollowRedirectsCommonsClientHttpRequestFactory extends CommonsClientHttpRequestFactory {
@Override
protected void postProcessCommonsHttpMethod(HttpMethodBase httpMethod) {
httpMethod.setFollowRedirects(true);
}
}
Затем вы можете использовать его так (с дополнительным, возможно, предварительно сконфигурированным экземпляром HttpClient), и запросы будут отвечать заголовкам location
в ответ:
RestTemplate restTemplate = new RestTemplate(
new FollowRedirectsCommonsClientHttpRequestFactory());