为了账号安全,请及时绑定邮箱和手机立即绑定

RAD - 如何在 websphere 应用程序服务器管理控制台中为 JAX-WS 添加用户名令牌

RAD - 如何在 websphere 应用程序服务器管理控制台中为 JAX-WS 添加用户名令牌

森林海 2022-07-20 10:49:36
我已经使用 JAX-WS 创建了一个 Web 服务,并尝试将 Simple UsernameToken 安全性添加到 Web 服务中。该应用程序部署在 Websphere 8.5 上。我发现以下链接有助于为基于 JAX-RPC 的 Web 服务添加来自RAD -> 服务选项卡的 usernameToken,但相同的功能不适用于JAX-WS类型的 Web 服务。RAD - 如何在 websphere 应用程序服务器管理控制台中为 JAX RPC 添加用户名令牌任何人都可以帮助提供一些类似的步骤或其他可能的简单解决方案来为 JAX-WS Web 服务实现相同的目标吗?    <Soapenv:Header>    <wsse:Security soapenv: mustUnderstand="1"        xmlns:wsse="http://docs.oasis-open.org/wss/2004/01/oasis-200401-wsswssecurity-secext-1.0.xsd">        <wsse:UsernameToken>            <wsse:Username>user</wsse: Username>            <wsse:Password                Type="http://docs.oasis-open.org/wss/2004/01/oasis-200401-wssusername-token-profile-1.0#PasswordText">paas</wsse: Password>        </wsse:UsernameToken>    </wsse:Security></soapenv:Header>
查看完整描述

1 回答

?
烙印99

TA贡献1829条经验 获得超13个赞

最后,我设法找到了解决上述问题的方法。它如下:


在谷歌上搜索了很多之后,我发现了一个Web 服务处理程序的概念,可以分别为从 Web 服务提供者接收或发送的每个请求和响应调用它。


如何配置: 1. 创建一个 Java File SecurityHandler 并在其中粘贴以下代码:


public class SecurityHandler implements SOAPHandler<SOAPMessageContext>

{

    @Override

    public boolean handleMessage(SOAPMessageContext context)

    {

        boolean outbound = (Boolean)context.get(SOAPMessageContext.MESSAGE_OUTBOUND_PROPERTY);

        if(outbound) {

            //logic to handle a response

        }


        if (!outbound) {

            //logic to handle a request

        }


        return true;

    }


    @Override

    public boolean handleFault(SOAPMessageContext context) {

        return true;

    }


    @Override

    public void close(MessageContext context) {}


    @Override

    public Set<QName> getHeaders() {

        return Collections.emptySet();

    }


}

使用以下代码示例创建一个 XML 文件:


<?xml version="1.0" encoding="UTF-8" standalone="yes"?>

<javaee:handler-chains 

     xmlns:javaee="http://java.sun.com/xml/ns/javaee" 

     xmlns:xsd="http://www.w3.org/2001/XMLSchema">

  <javaee:handler-chain>

    <javaee:handler>

      <javaee:handler-class>your.package.path.SecurityHandler</javaee:handler-class>

    </javaee:handler>

  </javaee:handler-chain>

</javaee:handler-chains>


要激活对您公开的 Web 服务的每个请求或响应的处理程序,请在 Web 服务类中添加注释,如下所示:



    @HandlerChain(file="/your/package/path/handler-chain.xml")

    公开课我的网络服务{

        //要公开的方法或网络服务。

    }


查看完整回答
反对 回复 2022-07-20
  • 1 回答
  • 0 关注
  • 143 浏览
慕课专栏
更多

添加回答

举报

0/150
提交
取消
微信客服

购课补贴
联系客服咨询优惠详情

帮助反馈 APP下载

慕课网APP
您的移动学习伙伴

公众号

扫描二维码
关注慕课网微信公众号