iceundead 2017-08-09 03:37 采纳率: 0%
浏览 4665

Mybatis如何动态修改查询结果?

需求是这样的:对查询数据库操作进行拦截,对不同权限的用户所返回的字段进行控制。

比如某个查询接口返回对象obj,obj里面有a,b,c三个字段。针对用户user1,可以将a,b,c三个字段全部返回。针对用户user2,只将a,b字段返回,c字段设置为null。

要求:用户的权限可在页面上调整,不同权限所返回的字段也可在页面做调整。调整后查询的结果也要相应变化,且无需修改代码或配置文件,也无需重启服务器。

目前进展:
使用mybatis拦截器拦截所有query操作,获取到返回对象obj。
public Object intercept(Invocation invocation) throws Throwable {
Object obj = invocation.proceed();
return obj;
}
目前问题:
无法判断obj的实际类型,也就无法强转类型修改里面的字段值。想过用instanceof判断,但使用instanceof时必须要知道你所要判断的类型。我建了一张表来存放类名、屏蔽字段、权限。

  • 写回答

2条回答 默认 最新

  • 唯灬独尊 2017-08-09 03:53
    关注

    dao层参数加一个user,然后mapper.xml中加if标签就可以

    评论

报告相同问题?

悬赏问题

  • ¥15 多电路系统共用电源的串扰问题
  • ¥15 shape_predictor_68_face_landmarks.dat
  • ¥15 slam rangenet++配置
  • ¥15 有没有研究水声通信方面的帮我改俩matlab代码
  • ¥15 对于相关问题的求解与代码
  • ¥15 ubuntu子系统密码忘记
  • ¥15 信号傅里叶变换在matlab上遇到的小问题请求帮助
  • ¥15 保护模式-系统加载-段寄存器
  • ¥15 电脑桌面设定一个区域禁止鼠标操作
  • ¥15 求NPF226060磁芯的详细资料