Orika 是一個 Java 對象映射框架,允許將一個類的屬性值映射到另一個類實例的屬性值,同時具有良好的性能和易用性。對於開發人員而言,大多數映射需求都可以通過 Orika 來實現。 Orika 還提供了許多定製選項和非常詳細的文檔供使用者參考。除此之外,它還是一個開源框架,所以可以輕鬆找到維護者和用戶社區。
一、Orika 概述
Orika 框架是由手頭忙於 Spring Boot 後端開發的開發者由於複雜對象轉換等問題創造的。Orika 的目標是提供一個使用簡單,性能優良,擴展性好的框架。Orika 是在 Apache License 下發布的。
Orika 可以在任何 Java 應用程序中使用,並在性能上優於其他大多數映射框架。 Orika 不僅僅只是映射簡單的屬性。 Orika 還支持從一個映射中排除某些字段,包含複雜集合的處理方式等等。
二、Orika 的使用
為了在應用程序中使用 Orika,您需要使用 Maven 或 Gradle 獲得 Orika 依賴。以下是 Maven 的配置示例:
<dependency> <groupId>ma.glasnost.orika</groupId> <artifactId>orika-core</artifactId> <version>1.5.2</version> </dependency>
使用 Orika 非常簡單。你需要創建一個 MapperFactory,這個 MapperFactory 用來構造 Mapper 實例。
MapperFactory mapperFactory = new DefaultMapperFactory.Builder().build();
構建 MapperFactory 對象後,你可以從 MapperFactory 中獲取一個實例化的 Mapper,同時使用 MapStruct 註解 來自動生成 Mapper 接口:
@Mapper public interface PersonMapper { @Mapping(source = "firstName", target = "name") PersonDto personToPersonDto(Person person); Person personDtoToPerson(PersonDto personDto); } PersonMapper personMapper = mapperFactory.getMapperFacade(PersonMapper.class);
在這個例子中,我們將 Person 對象轉變為 PersonDto 對象。註冊 Mapper 是一個非常顯式的過程,這使得 Orika 的行為和獲得基本類型的映射器非常相似。
三、Orika 的性能
由於 Orika 的核心是映射對象,因此它的性能是非常重要的。 Orika 實現的關鍵在於,它在映射兩個對象時,不會反射獲取目標屬 性的名稱和類型。取而代之的是,它將映射分解為類似於一個轉換表的方法,其中每個屬性都被處理為一個映射。 Orika 在內部使用了一個 HashTable 來存儲已經進行過映射的類,因此它能夠緩存這個信息,以便下次使用這個類時,能快速地找到屬性映射和構造函數。
性能測試的例子是,將含有一千萬個對象的列表進行映射:
List<Person> persons = createPersons(10000000); List<PersonDto> dtos; MapperFactory mapperFactory = new DefaultMapperFactory.Builder().build(); PersonMapper mapper = mapperFactory.getMapperFacade(PersonMapper.class); long t1 = System.currentTimeMillis(); dtos = mapperFacade.mapAsList(persons, PersonDto.class); long t2 = System.currentTimeMillis(); System.out.println("Orika takes " + (t2 - t1) + "ms to map " + persons.size() + " objects");
在我的筆記本電腦上,基於 Orika 的這種映射方式大約需要 4 秒鐘。結果顯示 Orika 的速度非常快,可以很好地處理10萬以上的對象列表。
四、Orika 的高級功能
Orika 提供了一系列高級映射選項。這些是常用選項的一個子集:
- 映射的上下文:此功能允許您從 MapperFacade 中的全局映射中獲取更多的信息,例如當前的目標對象。
- 自定義映射:您可以通過自定義轉換器來擴展到其他類型。這對於處理複雜類型很有用,例如將文本轉換為日期。
- 嵌套映射:Orika 可以從一個帶嵌套對象的源映射到帶嵌套對象的目標。
- 忽略特定屬性。
在以下示例中,我將演示如何在 Orika 中使用自定義轉換器和嵌套映射。
考慮以下兩個類:
public class Person { private String name; private String lastName; private LocalDate birthDate; } public class PersonDto { private String name; private String lastName; private String formattedBirthDate; }
我們將使用自定義轉換器將 LocalDate 轉換為字符串。
mapperFactory.getConverterFactory().registerConverter(new CustomDateConverter());
自定義轉換器:
public class CustomDateConverter extends BidirectionalConverter<LocalDate, String> { @Override public String convertTo(LocalDate localDate, Type<? extends String> type, MappingContext mappingContext) { return localDate.format(DateTimeFormatter.ofPattern("yyyy-MM-dd")); } @Override public LocalDate convertFrom(String s, Type<? extends LocalDate> type, MappingContext mappingContext) { return LocalDate.parse(s, DateTimeFormatter.ofPattern("yyyy-MM-dd")); } }
我們需要映射 Person -> PersonDto,現在我們可以使用自定義轉換器了:
@Mapper public interface PersonMapper { @Mappings({ @Mapping(source = "firstName", target = "name"), @Mapping(source = "lastName", target = "lastName"), @Mapping(source = "birthDate", target = "formattedBirthDate", converter = CustomDateConverter.class) }) PersonDto personToPersonDto(Person person); }
現在我們將演示如何處理映射嵌套對象的情況。我們再添加一個 Student 類,其內部包含一個 Person 類型的屬性以及其他屬性:
public class Student { private Person person; //Other properties }
我們將使用另一個 Mapper(用於將 Person 映射到 PersonDto ),然後在 StudentMapper 中引用它並進行嵌套映射。我們還將完成對 Person 和 Student 的映射。
@Mapper public interface StudentMapper { @Mapping(source = "person", target = "personDto") StudentDto studentToStudentDto(Student student); @Mapping(source = "name", target = "name") PersonDto personToPersonDto(Person person); }
注意,我們使用了 @Mapping(source = “person”, target = “personDto”) 將 Person 映射到 PersonDto 。在 StudentDto 中,我們使用的是新的轉換字段 personDto 。
總結
Orika 是一個簡單易用、高性能、支持高級映射選項的 Java 映射框架。您可以通過 Maven 或 Gradle 獲得 Orika,同時 Orika 在性能上優於其他大多數映射框架,可以幫助開發者更快速地編寫應用程序,同時極大提升了開發工作的便捷性。
原創文章,作者:小藍,如若轉載,請註明出處:https://www.506064.com/zh-hant/n/186462.html