HttpClient не выполняет перенаправления [duplicate]

Другое решение состоит в том, чтобы выполнить код через последовательный исполнитель 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

12
задан techie.brandon 2 April 2015 в 17:09
поделиться

2 ответа

Использование реализации по умолчанию 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.

15
ответ дан fateddy 26 August 2018 в 03:10
поделиться

При использовании команды 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());
0
ответ дан Mrkvozrout 26 August 2018 в 03:10
поделиться
Другие вопросы по тегам:

Похожие вопросы: