我需要记录多个微服务 api 调用,所以我有一个问题,如何直接从 java pojo 类创建 json 字符串。我的意思是说,例如,
MyPojo.java
public class MyPojo {
String name;
List<String> address;
public MyPojo() {
// TODO Auto-generated constructor stub
}
//setters and getters
}
现在我需要 pojo 的字符串 json 结构,而不创建类的对象。可能与 swagger api 在 Web UI 中创建 @RequestBody 对象的 json 结构的方式相同。
类似于:
String jsonStruct=SomeUtil.convertPojoToJson(MyPojo.class)
那么它应该给出如下:
{"name":"string","address":[]}
我的尝试:
import java.util.List;
import java.util.Map;
import com.fasterxml.jackson.core.JsonProcessingException;
import com.fasterxml.jackson.databind.ObjectMapper;
import io.swagger.v3.core.converter.ModelConverters;
import io.swagger.v3.core.util.Json;
import io.swagger.v3.oas.models.media.Schema;
public class TEst {
public static void main(String[] args) throws JsonProcessingException {
ObjectMapper obj = new ObjectMapper();
MyPojo o=new MyPojo();
o.setName("aa");
List<String> l=Arrays.asList("a","s");
o.setAddress(l);
System.out.println(obj.writeValueAsString(o));
}
}
实际成本:
{"name":"aa","address":["a","s"]}
所需的操作:
{"name":"string","address":["string"]}
问题:但是我需要在不创建对象的情况下进行创建,因为实际上 pojo 很大并且不可能设置所有虚拟数据。
最佳答案
您可以使用Podam
PODAM is a lightweight tool to auto-fill Java POJOs with data. This comes handy when developing unit tests. Thanks to PODAM users now have a one-liner that does all the work them.
在项目中添加 PODAM 依赖项
<dependency>
<groupId>uk.co.jemos.podam</groupId>
<artifactId>podam</artifactId>
<version>[latest.version]</version>
<!-- <scope>test</scope> -->
</dependency>
- 如果您不需要默认值(随机数据),请定义您的
DataProviderStrategy
- 定义
PodamFactory
bean,使用数据提供者策略初始化 - 在代码中使用
PodamFactory
bean
PodamFactory factory = new PodamFactoryImpl();
MyPojo myPojo = factory.manufacturePojo(MyPojo .class);
// write it as json
System.out.println(new ObjectMapper().writeValueAsString(myPojo));
关于java - 如何在不创建对象的情况下将java类转换为json格式结构,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/58831892/