我有一个类User,我从 system1 收到 JSON(用于 User 类),我应该读取信息,验证然后转发到 system2,我无法触及这两个系统,问题是键的名称不同,我想区分收到的 JSON 的反序列化名称和序列化名称之间是:
{"userId":"user1","pwd":"123456","country":"US"}
"{"username":"user1","password":"123456","country":"US"}"
但发送的应该是这样的
我正在使用 Gson lib,这是我的代码:
class User implements Cloneable {
@SerializedName("username")
private String username ;
@SerializedName("password")
private String password ;
@SerializedName("country")
private String country ;
}
Run Code Online (Sandbox Code Playgroud)
class TestJson {
private static GsonBuilder gsonBuilder;
private static Gson gson;
public static Object fromJson(String json, Class clz) {
gson = new Gson();
return gson.fromJson(json, clz);
}
public static String toJson(Object obj) {
gsonBuilder = new GsonBuilder();
gson = gsonBuilder.create();
String json = gson.toJson(obj);
return json;
}
public static void main(String[] args) {
String json2 = "{\"userId\":\"user1\",\"pwd\":\"123456\",\"country\":\"US\"}";
User user = (User) TestJson.fromJson(json2, User.class);
System.out.println(user.getPassword());
User u = new User("user1","123456","US");
String json1 = TestJson.toJson(u);
System.out.println(json1);
}
}
Run Code Online (Sandbox Code Playgroud)
如果字段有替代名称,只需使用@SerializedNamealternate的参数
public class User {
@SerializedName(value="username", alternate={"userId", "useriD"})
private String username ;
...
}
Run Code Online (Sandbox Code Playgroud)
您可以为此目的创建自定义序列化器/解串器。
序列化器:
public class UserSerializer implements JsonSerializer<User> {
@Override public JsonElement serialize(User obj, Type type, JsonSerializationContext jsonSerializationContext) {
..........
}
}
Run Code Online (Sandbox Code Playgroud)
解串器:
public class UserDeserializer implements JsonDeserializer<User> {
@Override public User deserialize(JsonElement json, Type typeOfT, JsonDeserializationContext context) throws JsonParseException {
...........
}
}
Run Code Online (Sandbox Code Playgroud)
并创建 Gson 实例:
GsonBuilder gsonBuilder = new GsonBuilder();
gsonBuilder.registerTypeAdapter(User.class, new UserSerializer());
gsonBuilder.registerTypeAdapter(User.class, new UserDeserializer());
Gson gson = gsonBuilder.create();
Run Code Online (Sandbox Code Playgroud)
编辑:这是一个自定义解串器的示例,可能适合您的需求。在这种情况下,我们不需要自定义序列化器。
添加这个UserDeserializer.java:
public class UserDeserializer implements JsonDeserializer<User> {
@Override
public User deserialize(JsonElement json, Type typeOfT, JsonDeserializationContext context) throws JsonParseException {
JsonObject obj = json.getAsJsonObject();
User user = new User(obj.get("userId").getAsString(), obj.get("pwd").getAsString(), obj.get("country").getAsString());
return user;
}
}
Run Code Online (Sandbox Code Playgroud)
以此替换您的fromJson实现(我使用泛型以避免调用时需要进行转换fromJson):
public static <T> T fromJson(String json, Class<T> clz) {
gsonBuilder = new GsonBuilder();
gsonBuilder.registerTypeAdapter(User.class, new UserDeserializer());
gson = gsonBuilder.create();
return gson.fromJson(json, clz);
}
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
5213 次 |
| 最近记录: |