benutzerdefinierte @ReadingConverter wird nicht ausgelöst, aber als ich diesen Code anfänglich implementierte, funktionierte er normal.@Configuration
public class ElasticsearchConfig {
@Bean
public MappingElasticsearchConverter mappingElasticsearchConverter() {
return new MappingElasticsearchConverter(new SimpleElasticsearchMappingContext());
}
@Bean
public ElasticsearchCustomConversions elasticsearchCustomConversions(
MappingElasticsearchConverter mappingElasticsearchConverter, ObjectMapper objectMapper) {
return new ElasticsearchCustomConversions(List.of(
new LogEntryReadingConverter(mappingElasticsearchConverter, objectMapper)
));
}
}
< /code>
Hier ist die Implementierung des Konverters: < /p>
@Component
@ReadingConverter
public class LogEntryReadingConverter implements Converter {
private final MappingElasticsearchConverter elasticsearchConverter;
private final ObjectMapper objectMapper;
public LogEntryReadingConverter(MappingElasticsearchConverter elasticsearchConverter, ObjectMapper objectMapper) {
this.elasticsearchConverter = elasticsearchConverter;
this.objectMapper = objectMapper;
}
public LogEntry convert(Document source) {
// Use Elasticsearch's internal conversion (respects @Field annotations)
LogEntry logEntry = elasticsearchConverter.read(LogEntry.class, source);
// some custom logic is here
return logEntry;
}
< /code>
Meine Dokumentklasse: < /p>
@Data
@JsonIgnoreProperties(ignoreUnknown = true)
@Document(indexName = "logstash")
public class LogEntry implements ILogModel {
@Id
private String id;
// more fields are here
}
< /code>
Meine Repository -Klasse: < /p>
@Repository
public interface HaProxyLogRepository extends ElasticsearchRepository {
Page findByTimestampBetween(LocalDateTime from, LocalDateTime to, Pageable pageable);
}
< /code>
Ich würde erwarten, dass die Konvertierungsmethode vor der Ausführung der Repository -Methode "findBytimestampbetween" auf dem Methode Call aufgerufen wird. Es hat zuvor funktioniert, aus irgendeinem seltsamen Grund löst es jetzt nie aus. < /P>
Ich verwende Spring Boot 3.1.2. und Federdaten Elasticsearch 5.1.2.
Federdaten elastische Suche benutzerdefinierte Konvertierungen funktionieren nicht ⇐ Java
-
- Similar Topics
- Replies
- Views
- Last post