首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Spring Security + Spring Remoting + Swing

Spring Security + Spring Remoting + Swing
EN

Stack Overflow用户
提问于 2017-07-12 08:53:17
回答 1查看 639关注 0票数 1

我有一个基于spring的应用程序,由spring-security保护。服务是通过HttpInvoker公开的,我想从一个基于Swing的客户端使用这些服务。

我知道如何通过HttpInvokerProxyFactoryBean在Swing客户端中使用这些远程服务。但是我找不到一个好的例子来处理我的基于swing的客户端的身份验证。你能给我指引正确的方向吗?

EN

回答 1

Stack Overflow用户

发布于 2017-07-12 10:32:02

我设法完成了它,并在这里发布了答案,以帮助任何有同样问题的人。

在您的swing客户端中,按如下方式设置HttpInvokerProxyFactoryBean。

代码语言:javascript
复制
@Bean
public HttpInvokerProxyFactoryBean invoker(AuthenticationSimpleHttpInvokerRequestExecutor httpInvokerRequestExecutor) {
    HttpInvokerProxyFactoryBean invoker = new HttpInvokerProxyFactoryBean();
    invoker.setServiceUrl(<URL_HERE>);
    invoker.setServiceInterface(DeliveryService.class);
    invoker.setHttpInvokerRequestExecutor(httpInvokerRequestExecutor);
    return invoker;
}

您的客户端中还需要有一个如下所示的。

代码语言:javascript
复制
@Bean
public AuthenticationSimpleHttpInvokerRequestExecutor httpInvokerRequestExecutor() {
    return new AuthenticationSimpleHttpInvokerRequestExecutor();
}

然后,你必须在你的本地SecurityContext中设置你的用户名和密码,如下所示。

代码语言:javascript
复制
ConfigurableApplicationContext context = SpringApplication.run(Application.class);
    SecurityContextHolder.getContext().setAuthentication(new UsernamePasswordAuthenticationToken(<Username>, <Password>));

都设置好了,现在您可以检索下面的服务bean了。

代码语言:javascript
复制
<ServiceInterface> service = context.getBean(<ServiceInterface>.class);

您还必须在服务器的安全配置中启用HTTP基本身份验证。否则,您将得到StreamCorruptedException。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/45046604

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档