如何使用soapUI发送包含wss认证请求

什么是wss认证?wss全称是WebService Security。对于wss认证详细参考以下链接:

https://www.oasis-open.org/committees/download.php/16782/wss-v1.1-spec-os-UsernameTokenProfile.pdfhttps://www.oasis-open.org/committees/download.php/16782/wss-v1.1-spec-os-UsernameTokenProfile.pdf

接下来进入正题,如何使用soapUI发送包含wss认证请求,其实是往请求报文中填入红框部分:

在请求前需要server提供信息:①帐号密码②密码类型(passwordDigest和passwordText)

1.使用soapUI创建soap项目,并填入基础报文:

2.点击Reuqest 1,填入Username和Password,一般由server端提供

 

3.添加ws timestamp内容,因为server会校验当前时间是否在时间范围,测试间隔时间超过60s,则需要删掉security节点并重新添加。

右键空白处点击Add WS-Timestamp选项

设置过期时间,单位秒: 

 

点击确定后出现Security部分:

4.添加wss username token模块

 在空白处右键,点击Add WSS Username Token

此处会让你选择PasswordDigest(加密密码)还是PasswordText(明文密码),取决于server方如何校验:

点击确定后会出现UsernameToken部分:

到此已经完成所有步骤,可以愉快的请求server了~

Troubleshooting:

  •  请求server时出现错误:A security error was encountered when verifying the message

      server出现的错误信息:Caused by: org.apache.wss4j.common.ext.WSSecurityException: Invalid timestamp: The message timestamp has expired

原因和解决方式:

      ws timestamp时间过期,需删除security节点重新添加ws timestamp和wss usernametoken

  •  请求server时出现错误:A security error was encountered when verifying the message

      server出现的错误信息:Caused by: org.apache.wss4j.common.ext.WSSecurityException: An error happened processing a Username Token: "A replay attack has been detected"

原因和解决方式:

     ws UsernameToken中的Nonce中加密内容有当前时间,需删除security节点重新添加ws timestamp和wss usernametoken

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值