Как предотвратить Джексон от вывода pretty print JSON?

Я хочу убедиться,что файлы JSON, созданные Джексоном, никогда не печатаются. Я младший, работающий над ранее существующим проектом, поэтому мне нужно работать в обратном направлении, чтобы узнать все способы, которыми JSON можно настроить для вывода Как pretty print. Я могу подтвердить, что есть 0 ссылок .defaultPrettyPrintingWriter () в проекте, а также 0 ссылок на.setSerializationConfig, который, я считаю, также может быть использован для включения красивой печати.

Так как же еще это возможно? Кроме того, есть ли верный способ убедиться, что файл JSON не является красивой печатью?

3 ответов


в зависимости от того, какую версию Spring вы используете MappingJacksonHttpMessageConverte‌​r должны иметь логическое свойство с именем prettyPrint настройка принтера при сериализации JSON.

таким образом, эта конфигурация XML должна сделать трюк (если вы используете последнюю версию Spring 3)

<bean class="org.springframework.web.servlet.mvc.annotation.AnnotationMethodHandlerAda‌​pter">
  <property name="messageConverters">
    <list>
      <ref bean="jsonConverter" />
    </list>
  </property>
</bean>

<bean id="jsonConverter" class="org.springframework.http.converter.json.MappingJacksonHttpMessageConverte‌​r">
  <property name="supportedMediaTypes" value="application/json" />
  <property name="objectMapper" ref="jacksonObjectMapper" />
  <property name="prettyPrint" value="false" />
</bean>

вы можете увидеть связанный commit на GitHub представляя свойство. И хобот версия класса слишком, Что включает в себя это свойство. Наконец, это Весенний выпуск Jira SPR-7201 связано с предыдущей фиксацией.

или вы можете попробовать обновить свою версию Jackson до более последней, которая включает в себя useDefaultPrettyPrinter и setPrettyPrinter методы, упомянутые Александром Рыжовым


самое элегантное решение-поместить переключатель для pretty / non-pretty в фильтр и повторно использовать статические объекты конфигурации. Это предотвращает бесполезные сборки мусора.

/**
 * Evaluate the "pretty" query parameter. If given without any value, or with "true": pretty JSON output.
 * E.g. /test?pretty or /test?pretty=true
 * Otherwise output without any formatting.
 *
 * @see https://stackoverflow.com/questions/10532217/jax-rs-json-pretty-output
 */
@Provider
@Produces(MediaType.APPLICATION_JSON)
public class RestPrettyJsonFilter implements ContainerResponseFilter {

  public static final String QUERYPARAM_PRETTY = "pretty";

  private static final IndentingModifier INDENTING_MODIFIER_PRETTY = new IndentingModifier(true);
  private static final IndentingModifier INDENTING_MODIFIER_NOT_PRETTY = new IndentingModifier(false);

  @Override
  public void filter(ContainerRequestContext reqCtx, ContainerResponseContext respCtx) throws IOException {

    boolean pretty = false;

    UriInfo uriInfo = reqCtx.getUriInfo();
    //log.info("prettyFilter: "+uriInfo.getPath());

    MultivaluedMap<String, String> queryParameters = uriInfo.getQueryParameters();
    if(queryParameters.containsKey(QUERYPARAM_PRETTY)) {
      // Pretty query parameter is present
      String prettyParam = queryParameters.getFirst(QUERYPARAM_PRETTY);

      // Pretty is present without any value, or value is set to "true"?
      if (prettyParam == null || "".equals(prettyParam) || "true".equals(prettyParam)) {
        pretty = true;
      }
    }

    // Prevent recreation of objects over and over again
    //ObjectWriterInjector.set(new IndentingModifier(pretty));
    if (pretty) {
      ObjectWriterInjector.set(INDENTING_MODIFIER_PRETTY);
    } else {
      ObjectWriterInjector.set(INDENTING_MODIFIER_NOT_PRETTY);
    }
  }

  /**
   * Used to switch on / off pretty output for each response.
   */
  public static class IndentingModifier extends ObjectWriterModifier {

    private final boolean indent;

    /** Minimal pretty printer is not printing pretty. */
    private final static PrettyPrinter NOT_PRETTY_PRINTER = new com.fasterxml.jackson.core.util.MinimalPrettyPrinter();

    public IndentingModifier(boolean indent) {
      this.indent = indent;
    }

    /* (non-Javadoc)
     * @see com.fasterxml.jackson.jaxrs.cfg.ObjectWriterModifier#modify(com.fasterxml.jackson.jaxrs.cfg.EndpointConfigBase, javax.ws.rs.core.MultivaluedMap, java.lang.Object, com.fasterxml.jackson.databind.ObjectWriter, com.fasterxml.jackson.core.JsonGenerator)
     */
    @Override
    public ObjectWriter modify(EndpointConfigBase<?> endpointConfigBase, MultivaluedMap<String, Object> multivaluedMap, Object o, ObjectWriter objectWriter, JsonGenerator jsonGenerator) throws IOException {
      if(indent) {
        // Pretty
        jsonGenerator.useDefaultPrettyPrinter();
      } else {
        // Not pretty
        jsonGenerator.setPrettyPrinter(NOT_PRETTY_PRINTER);
      }
      return objectWriter;
    }
  }
}

не уверен, какую версию Jackson вы используете, но в последней версии (1.9.10), поведение по умолчанию JsonGenerator не довольно печати. Самый простой способ включить его-позвонить generator.useDefaultPrettyPrinter() или generator.setPrettyPrinter(new DefaultPrettyPrinter()). Попробуйте найти useDefaultPrettyPrinter и setPrettyPrinter и удалите эти заявления.