最近做个项目,biztalk跟OTM(Oracle Transportation Management)系统做对接,双方通过web services通讯,这部分是BizTalk调用OTM的web services。
OTM的云服务,仅支持WS-Security的Username Token验证方式。
所以需要使用UsernameToken Web Service Security Policy,并使用HTTPS加密此SOAP消息的传输。
OTM发布的web services是基于java的,也就是说这也是个biztalk调用的java开发的基于WS-Security的web services的例子。
https的请求内容格式如下:
POST https://URL HTTP/1.1
Content-Type: text/xml; charset=utf-8
SOAPAction: "process"
Host: host
Content-Length: 6115
Expect: 100-continue
Accept-Encoding: gzip, deflate
Connection: Keep-Alive
<env:Envelope xmlns:env="http://schemas.xmlsoap.org/soap/envelope/" xmlns:ns1="http://docs.oasis-open.org/wss/2004/01/oasis-200401-wss-wssecurity-secext-1.0.xsd">
<env:Header>
<ns1:Security>
<ns1:UsernameToken>
<ns1:Username>GUEST.ADMIN</ns1:Username>
<ns1:Password>CHANGEME</ns1:Password>
</ns1:UsernameToken>
</ns1:Security>
</env:Header>
<env:Body>
...your message content goes here...
</env:Body>
</env:Envelope>
-
引用OTM的web services
在VS的BizTalk project中使用ADDàAdd Generated Items… à Consume WCF Service:
引用OTM的web services提供的wsdl URL:
WSDL包括相应的xsd文件能够获取到,点击下一步就会出错:
试过N多次,在这一步死活就是过不去,引用不成功,只能理解为双方兼容性问题。
引用在线的wsdl不成功,就试试引用wsdl文件。使用svcutil.exe工具根据web
Services提供的wsdl的URL生成wsdl和相应的xsd文件:
可以看到生成了两个文件:xmlns.oracle.com.apps.otm.IntXmlService.wsdl和xmlns.oracle.com.apps.otm.xsd,这就是biztalk引用文件wsdl的原料了。
再在VS的BizTalk project中使用ADDàAdd Generated Items… à Consume WCF Service,这次选Metadata File:
下一步:
选择前面生成的两个文件,一个wsdl文件,一个xsd文件。结果还是出错:
把wsdl文件和xsd合并成一个文件再试。
查看wsdl文件如下:
把xmlns.oracle.com.apps.otm.xsd的内容整个的替换掉红框内的内容,把两个文件合并为一个wsdl文件,在bizitalk project再次引用成功,生成三个文件:
-
部署BizTalk项目测试
部署这个BizTalk项目后,在biztalk application中导入端口的绑定文件:IntXmlService.BindingInfo.xml,可以看到这是一个WCF-Custom发送端口:
点击这个端口的"Configure…":
Bingding标签的内容:
设置好对方提供的用户名和密码:
设置一个接收端口从一个文件夹接收测试文件,这个发送端口设置Filter订阅这个接收端口,然后再设置一个发送端口订阅这个发送端口返回的消息写到一个文件夹,这个具体过程就不详细描述了。
开始测试,将一个从xsd schema生成的消息实例发送给对方,使用Fiddler截取发送和返回的消息看。
截取到的发送出去的消息是这样的:
截取到的返回的消息是这样的:
很明显,对方返回的消息说安全验证错误。
查看发送出去的消息里面,发现在Envelope里没有Header,就没有把Username Token发送给对方。
仔细检查WCF-Custom发送端口的配置,发现缺少Security的配置。
在发送端口的Binding标签中增加Security Extension:
把security移到最上面的位置,然后设置authenticationMode为UserNameOverTransport,把enableUnsecuredResponse设置为True。
再测试,使用Fiddler截取发送和返回的消息看。
截取到的发送出去的消息是这样的:
可以看到,Envelope中的Header有了,UsernameToken也有了。
截取到的返回的消息是这样的:
可以看到,这个就是对方的正常回应消息了。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· 周边上新:园子的第一款马克杯温暖上架
· 分享 3 个 .NET 开源的文件压缩处理库,助力快速实现文件压缩解压功能!
· Ollama——大语言模型本地部署的极速利器
· DeepSeek如何颠覆传统软件测试?测试工程师会被淘汰吗?
· 使用C#创建一个MCP客户端
2007-12-12 biztalk中的发送端口产生异常及处理(上)