java 单侧 忽略异常注解,Java后端避坑——不使用注解如何忽略掉JavaBean的属性值...

昨天给小伙伴们介绍了使用@JsonIgnore注解忽略JavaBean属性值的好处,有小伙伴说那如果不使用该注解呢,又该怎么写?其实我在前文有稍微提了一下,就是把setPassword设置为null值,不过没有展示具体的代码来进行对比,所以今天把不使用注解的方法给大家也顺便介绍一下,只是写起来稍微比一个注解麻烦了一点而已。 好了,不多说了,直接看代码。

先定义一个普通的Bean:

public class Hr {

private String hrname;

private String password;

public String getHrname() {

return hrname;

}

public void setHrname(String hrname) {

this.hrname = hrname == null ? null : hrname.trim();

}

public String getPassword() {

return password;

}

public void setPassword(String password) {

this.password = password == null ? null : password.trim();

}

//重载setPassword 方法,并设置为null

public void setPassword(){

this.password = null;

}

}

复制代码

登录成功的时候认证的方法:

public void onAuthenticationSuccess(HttpServletRequest req, HttpServletResponse resp, Authentication authentication) throws IOException, ServletException {

resp.setContentType("application/json;charset=utf-8");

PrintWriter out = resp.getWriter();

ObjectMapper om = new ObjectMapper();

Hr hr = (Hr)authentication.getPrincipal();//获取Hr对象

hr.setPassword();//获取被设置为null值的密码

String s = om.writeValueAsString(RespBean.ok("登录成功!",hr));

out.write(s);

out.flush();

out.close();

}

复制代码

因为Authentication获取的是一个Object对象,要获取用户信息中的密码,我们需要进行向下转型获取Hr对象然后再去获取密码,这样会变得麻烦了很多。所以强烈推荐使用@JsonIgnore注解!

使用Postman得到的测试结果如下:

96429a1bf37920c88d98baf02789be6b.png

积少成多,滴水穿石!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值