ObjectMapper in Spring konfigurieren
In Spring kann der ObjectMapper konfiguriert werden, um das Verhalten von Serialisierungs- und Deserialisierungsprozessen anzupassen. Ein häufiger Anwendungsfall besteht darin, Felder von der Serialisierung auszuschließen, es sei denn, sie sind mit einer bestimmten Annotation wie @JsonProperty versehen.
Problem:
Beim Konfigurieren des ObjectMappers Wenn Sie nur mit @JsonProperty annotierte Felder serialisieren, enthält die NumbersOfNewEvents-Klasse weiterhin alle Attribute in der serialisierten JSON.
Antwort:
Der Schlüssel zum Verständnis dieses Problems liegt darin, dass der in servlet.xml definierte benutzerdefinierte CompanyObjectMapper von Spring nicht verwendet wird. Die Lösung besteht darin, die CompanyObjectMapper-Bean mit @Configuration zu annotieren und sie als Bean-Methode in einer Spring-Konfigurationsklasse zu definieren. Dadurch wird sichergestellt, dass der benutzerdefinierte ObjectMapper von Spring übernommen und verwendet wird.
Hier ist ein Beispiel, wie dies mit Spring Boot erreicht wird:
@Configuration public class JacksonConfiguration { @Bean public ObjectMapper objectMapper() { return new CompanyObjectMapper(); } }
Diese Konfiguration überschreibt die Standard-ObjectMapper-Bean und stellt sicher, dass der benutzerdefinierte CompanyObjectMapper für die Serialisierung und Deserialisierung verwendet wird.
Hinweis: Der Der in der CompanyObjectMapper-Klasse definierte VisibilityChecker hat keine Auswirkung auf die Serialisierung mit Jackson 2.4.6. Um Felder von der Serialisierung auszuschließen, verwenden Sie stattdessen die Annotation @JsonIgnore.
Das obige ist der detaillierte Inhalt vonWie kann ich Spring dazu bringen, meinen benutzerdefinierten ObjectMapper für die Serialisierung und Deserialisierung zu verwenden?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!