问题描述
我已将 spring-boot 应用程序从 1.5.10 升级到 2.2.2。
我有一种方法可以在用户通过身份验证之前在登录页面上调用。因此该方法在安全配置中被标记为 final
。此方法调用 permitAll()
从数据库中获取数据。
JPA 代码如下:
userRepository
每个实体都经过审核。该方法仅获取数据而不更新任何实体。
仍然会调用 @Query("SELECT t2 FROM table t1 INNER JOIN t1.table2 t2 WHERE t1.id = :param1 and t2.id = :param2")
SomeEntity getsomedata(@Param("param1") long param1,@Param("param2") long param2);
方法。在 @PreUpdate
方法中,我们让经过身份验证的用户将一些信息记录到审计表中。因此调用获取数据库数据失败,因为用户未通过身份验证。
为什么 @PreUpdate
被调用,因为我们没有更新任何数据?
这是在 spring boot 1.5.10 版本中工作的
正如我在调用 get call flush 方法后看到的日志。
@PreUpdate
解决方法
暂无找到可以解决该程序问题的有效方法,小编努力寻找整理中!
如果你已经找到好的解决方法,欢迎将解决方案带上本链接一起发送给小编。
小编邮箱:dio#foxmail.com (将#修改为@)