PO系列之 PO中使用webService

点击蓝字 关注我们

前言

PO(/PI)是SAP公司的一个中间件产品,用来辅助连接SAP系统与外围系统. (当然外围系统之间也可以使用PO).

作为中间件,PO支持很多与系统交互的方式(RESTful, SOAP ,JDBC, FILE )等等

百度了一下 webService 与SOAP的关系(如图一)

可以看出SOAP只是webService三要素之一, 用来描述传递信息的格式

本文主要介绍webService在PO中的应用及特殊映射方式

图一

ABAP与webService

ABAP可以直接引入或发布webService.

详见连接无峰,公众号:ABAP 技巧与实战SAP操作手册之 ABAP调用WEB服务
详见连接无峰,公众号:ABAP 技巧与实战SAP操作手册之 RFC函数发布WEB服务

webService的优点

个人认为webService的最大优点就在于包含了WSDL

(WebServicesDescriptionLanguage) . WSDL包含了这个接口的几乎所有信息

  • 数据定义 :接口传递内容的结构定义及类型

  • 调用地址 :服务提供的调用地址

  • 调用点  :服务提供的调用点 SOAP ACTION

并且大部分的软件都支持引入WSDL定义生成调用接口的类,方便应用中直接使用.

比如ABAP引入WSDL产生类.调用类的方法就是调用接口.

SOAPUI与WSDL

把WSDL定义引入到SOAPUI(一个应用广泛的接口测试工具)中可以看到接口的这些信息(数据定义,调用地址,调用点)

(当然,也可以用浏览器打开WSDL定义的地址或者文件,只是可读性相对较差)

PO引入WSDL

PO不支持直接引入WSDL地址.

但是可以通过IE浏览器(新版的浏览器似乎没有另存为功能)把地址另存为文件.

然后在ESB中创建 External Definition 引入WSDL文件.

创建的External Definition 代替了标准的 data type 和 message type . (图二) .

Service Interface 中可以直接使用引入的External消息(图三)

图二
图三

SOAP接收通道

其中 Target URL 就是通过SOAPUI 看到的调用url地址 SOAP action 就是SOAPUI中看到的调用点,接收通道每个接口需要单独定义,因为其中包含了每个接口的特性: 调用地址,调用点

SOAP发送通道

发送通道只需要定义一些通用属性 安全层级 同步/异步属性. 在PO中可以共用SOAP发送通道

特殊的webService

有些系统为了简化或者统一化接口调用. 会发布一种特殊的webService .

这种webService中只有一个string字段. 如下图所示. 调用方需要在这个字段中填入XML或JSON内容. 接收方需要解析这个字段中的XML或JSON内容. 根据解析的结果再确定后续处理方式.

  • 优点:可以用一个接口实现所有业务信息的传输.

  • 缺点:WSDL定义丢失了业务含义.不便于调用方理解接口需要传输的内容.

不推荐使用这种webService定义方式, 因为他丢失了三要素之一: 数据定义

PO与特殊webService

PO可以通过MAPPING 把一个XML结构映射到一个字段中. 过程如下.

该方式的原文链接如下

https://blogs.sap.com/2010/06/17/convert-the-input-xml-to-string-in-pi-71-using-standard-graphical-mapping/

01

源结构

02

目标结构

03

映射

任何一个文本函数(例如trim) . 右键点击源字段,勾选 return as xml

04

源消息

05

目标消息

实际接口处理时,PO为了避免嵌套XML的解析错误, 会使用特殊字符

这种使用转义字符取代 < > 只是为了避免XML的解析错误. 并体现XML的嵌套.不影响系统对XML的解析.

局限性

PO对特殊webService的MAPPING 存在局限性.

PO MAPPING可以把一个XML结构MAPPING 到一个字段中. 但是因为一个PO接口只有一次MAPPING. 所以无法同时实现字段映射及XML映射到字段. 如果要实现这种复杂的映射,估计需要使用JAVA开发映射逻辑来实现.

一个变通的方法是把一个接口拆分成两个接口, 让PO本身作为一个中转系统.

比如接口

  • 系统A -> 系统B

可以调整为

  • 系统A->PO虚拟

  • PO虚拟->系统B

这样就可以通过两次映射:第一次执行字段隐射, 第二次再把XML结构映射到一个字段. 来实现这个功能. 只是PO的配置量增大了一倍.

十一

总结

webService是应用广泛的接口方式,几乎所有软件对webService有良好的支持.

一般项目中,如果外围系统不是现成的接口, 都建议使用webService方式和外部系统交互.

通过webService的WSDL定义可以解决双方系统对传输内容结构及字段定义的分歧.快速完成接口的调用(无论是否使用PO). 当然这要建立在不使用特殊webService的基础上.

THE

END

约定

如果你对这篇文章感兴趣,请帮忙点赞,在看,分享.     

    (如果你真的喜欢这篇文章,请记得回来打个赏,作为支持我继续下去的动力,这是一个正反馈过程. 越多的人打赏,作者越有动力分享,读者就能享受更多的福利.毕竟打赏的金额富不了我,穷不了你,却能支持这个公众号长久发文.)


最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • WebService学习笔记 友情提示,本文档的图床使用极简图床进行图片存储,默认存储到七牛云空间 本学习贴是根据...
    Mr_魏阅读 4,791评论 0 5
  • WebService学习系列之基础理论知识 本系列文章将介绍WebService是什么、 WebService的应...
    理想是一盏灯阅读 5,795评论 0 1
  • alert(a); function name(parameters) { alert(parameters); ...
    name阿喆azhe阅读 4,979评论 0 3
  • IOC 控制反转容器控制程序对象之间的关系,而不是传统实现中,有程序代码之间控制,又名依赖注入。All 类的创建,...
    irckwk1阅读 4,650评论 0 0
  • 16宿命:用概率思维提高你的胜算 以前的我是风险厌恶者,不喜欢去冒险,但是人生放弃了冒险,也就放弃了无数的可能。 ...
    yichen大刀阅读 11,649评论 0 4

友情链接更多精彩内容