如何将AuthenticatedWebSession存储在分布式内存缓存中 - java

我正在尝试将wicket-6应用程序部署到kubernetes集群中,以提高可用性并更好地分配Web应用程序的负载。

就我扩展AuthenticatedWebSession而言,这是一个有状态的Web应用程序。我想将此会话对象存储在Apache Ignite之类的分布式缓存中,这样我就不需要在负载均衡器上进行粘性会话。

问题是我的实现将AuthenticationManager注入到AuthenticatedWebSession中,因此可以在authenticate(username,password)方法中使用authManager。

@SpringBean(name = "webAuthenticationManager")
private AuthenticationManager authManager;

@Override
public boolean authenticate(String username, String password) {

    boolean authenticated = false;
    try {
        authentication = authManager.authenticate(new UsernamePasswordAuthenticationToken(username, password));
        authenticated = true;
    } catch (AuthenticationException e) {
        authenticated = false;
    }
    return authenticated;
}

Caused by: org.apache.ignite.binary.BinaryObjectException: Failed to read field [name=authManager]
at org.apache.ignite.internal.binary.BinaryFieldAccessor.read(BinaryFieldAccessor.java:192)
at org.apache.ignite.internal.binary.BinaryClassDescriptor.read(BinaryClassDescriptor.java:875)

当Ignite尝试序列化/反序列化authManager字段时,就会出现此问题。实际上,我不需要管理器本身存储在缓存中。

从高速缓存还原会话时,是否可以重新注入该对象?

也许我正在处理完全错误的问题。有点像我要去这里的兔子洞:)

参考方案

由于它是@SpringBean,因此实例是java.lang.reflect.Proxy或CGLIB代理。代理易于(反)序列化,因为它们没有将真实实例作为硬参考。他们通过Spring的应用程序上下文动态地查找Spring bean。
请参见wicket-spring模块中的类的源。他们只是其中的几个。
如果Ignite使用普通的Java序列化,那么它应该可以工作,但是可能有一些自定义项。

java:继承 - java

有哪些替代继承的方法? java大神给出的解决方案 有效的Java:偏重于继承而不是继承。 (这实际上也来自“四人帮”)。他提出的理由是,如果扩展类未明确设计为继承,则继承会引起很多不正常的副作用。例如,对super.someMethod()的任何调用都可以引导您通过未知代码的意外路径。取而代之的是,持有对本来应该扩展的类的引用,然后委托给它。这是与Eric…

Java-如何将此字符串转换为日期? - java

我从服务器收到此消息,我不明白T和Z的含义,2012-08-24T09:59:59Z将此字符串转换为Date对象的正确SimpleDateFormat模式是什么? java大神给出的解决方案 这是ISO 8601标准。您可以使用SimpleDateFormat simpleFormat = new SimpleDateFormat("yyyy-MM…

Java:从类中查找项目名称 - java

仅通过类的实例,如何使用Java反射或类似方法查找项目名称?如果不是,项目名称(我真正想要的是)可以找到程序包名称吗? 参考方案 项目只是IDE使用的简单组织工具,因此项目名称不是类或JVM中包含的信息。要获取软件包,请使用Class#getPackage()。然后,可以调用Package#getName()将包作为您在代码的包声明中看到的String来获取…

JAVA 8具有任何匹配属性的对象的过滤器列表 - java

我的要求是通过匹配任何属性的字符串来过滤对象列表。例如,假设Contact类具有三个属性:街道,城市,电话。我知道java流过滤器是如何工作的,在这里我必须将输入字符串与每个属性进行比较,如下所示:contactList.stream().filter(contact -> contact.getStreet().equals("dubai&…

Java-固定大小的列表与指定初始容量的列表之间的差异 - java

我在理解这一点上遇到了问题。当我们做 List<Integer> list = Arrays.asList(array); 我们不能在该列表上使用添加,删除之类的方法。我知道Arrays.asList()返回固定大小的列表。我不明白的是,如果我们创建一个具有指定初始容量的列表,例如List<Integer> list2 = new A…