【SpringBoot】接口返回值结构与实体类结构不一致的场景

背景

上周参与了一个新项目,刚进来就给了一个新需求,两周上线。我主要是负责编写Java后端。在写的时候发现有一些场景里,前端用到的数据和表里的数据不太一样,有时候要多一些字段,有时候要少一些字段。在此结合我遇到的实际场景,将用到的知识点记录下来。

场景一:Jackson注解------@JsonIgnore

某个接口会返回用户信息,但是我不希望一些敏感信息返回给前端,比如用户的密码。这个时候可以在class的密码字段上添加@JsonIgnore,表示在接口返回的时候不返回该字段。

java 复制代码
public class User{
    @JsonIgnore
	String password;
	// ...
}

场景二:Jackson注解------@JsonUnwrapped

某个接口需要把这个用户信息再封装一层,封装一个所属学校的信息,一起返回回来。这个信息需要在另一个表查出来。这个时候我不可能重新定义一个类把用户的字段又写一遍。这个类和用户类相比,就多了一个学校字段。我的做法就是用继承extends,把用户类继承到这个类上。

但是这样又会遇到一个问题,在返回的时候会返回一个嵌套的对象。而前端希望的是就返回一个对象,不包含其他嵌套对象。这个时候就可以用@JsonUnwrapped添加到用户类字段上,这样就可以实现把字段解耦出来,和学校信息放在同一级的对象字段里,而不是嵌套的对象里。

java 复制代码
public class NewUser extends User {
    String schoolName;
    @JsonUnwrapped
	User user;
}

场景三:Jackson注解------@JsonRawValue

某个接口的某个字段是Json字符串,这样直接返回的话,前端不好取值。这里就用到@JsonRawValue,在接口返回的时候可以自动转成Object对象。

java 复制代码
public class Ob {
	@JsonRawValue
    String jsonString;
}

这里提一句,Jackson本身也有提供ObjectMapper类,可以用来将json对象和String之间的相互转化。

ObjectMapper是Jackson提供的一个类。我主要用到了两个方法:readValue, writeValueAsString

  • readValue用于将json -> Object
  • writeValueAsString用于将Object -> json

场景四:@TableField(exist=False)

这个注解用来传输数据库里没有的、我想临时加上去的字段。

比如之前在写七牛云的项目的时候,存储到七牛云中的资源会有一个名称,这个名称是保存在类里的。如果要访问这个资源,需要先利用七牛云api根据名称构建url,返回这个url给前端,前端才能访问。但问题是,这个构建的这个过程会有时间信息(好像是过一段时间就会失效)。这样就只能在每次请求接口的时候,构建一次url,放到类中,最后返回给前端。

这里就要用到这个字段

java 复制代码
public class Resource {
    String name; // 名称
    @TableField(exist=False)
    String url; // 资源链接
    public void setUrl(String url) {
		this.url = url;
	}
}
相关推荐
子木HAPPY阳VIP1 小时前
Ubuntu 22.04 VMware 设置固定IP配置
人工智能·后端·目标检测·机器学习·目标跟踪
人间打气筒(Ada)1 小时前
如何基于 Go-kit 开发 Web 应用:从接口层到业务层再到数据层
开发语言·后端·golang
开心就好20251 小时前
使用Wireshark进行TCP数据包抓包分析:三次握手与四次挥手详解
后端·ios
用户4419395054871 小时前
OpenClaw服务器部署保姆级教程
后端
zdl6861 小时前
springboot集成onlyoffice(部署+开发)
java·spring boot·后端
Soofjan1 小时前
sync.Mutex讲解
后端
Soofjan1 小时前
sync.RWMutex 源码解析
后端
code_Bo1 小时前
使用AI完成Swagger接口类型在前端自动生成的工具
前端·后端·架构
开心就好20251 小时前
Flutter iOS 包破解风险处理 可读信息抹除
后端·ios
架构师沉默2 小时前
AI 让程序员更轻松了吗?
java·后端·架构