给用过SAP CRM中间件的老哥老姐们讲讲SAP CPI
最近Jerry由于項目需要,又得學習一個新工具:SAP Cloud Platform Integration,簡稱CPI,以前又叫做HCI - HANA Cloud Platform Integration Service.
盡管距離Jerry開始接觸CPI還不到48小時,我仍然想把我剛使用這個工具的第一手體會分享給曾經用過SAP CRM中間件,但尚未有機會接觸到CPI的朋友們。
之所以文章標題里把SAP CRM中間件和SAP CPI關聯在一起,是因為二者同廣義上說,扮演的都是系統集成里中間件的角色。
SAP ERP和CRM通過qRFC進行業務數據同步,而中間件能夠提供隊列機制,錯誤處理,重試,傳輸監控等功能。關于Jerry在SAP CRM中間件上的工作經驗分享,請參考我的文章 Jerry的CRM Middleware(中間件)文章合集。
而SAP CPI顧名思義,則是云時代下SAP推薦的SAP產品同第三方云產品進行集成的云端中間件解決方案。Jerry的S4CRM同事童丹之前文章 S/4HANA Service Management和SAP Field Service Management的集成 里提到的場景就是SAP CPI的一個典型集成應用。
作為學習筆記,Jerry這里把我學習SAP CPI時做的一個Hello World級別的練習步驟記錄下來。
這個練習的場景是,假設有一個部署在第三方云平臺上的OData服務,提供了產品主數據查詢的功能。我們需要在SAP系統里消費這個OData服務。SAP開發人員不希望直接去消費第三方云平臺上的OData服務,而是期望SAP CPI能暴露一個更加容易訪問的API endpoint出來,例如通過postman傳一個Product ID給CPI,CPI拿到這個ID后,由CPI向第三方云平臺發起OData請求,拿到請求響應后,CPI把結果返回給位于SAP產品的消費端。
用于這個場景的OData服務地址:https://espmrefapps.hana.ondemand.com/espm-cloud-web/espm.svc/$metadata
SAP CPI是一個SaaS應用,在SAP云平臺控制臺的Subscriptions面板里訂閱和訪問。點擊Go to Applications進入主操作頁面。
我們為了實現這個集成場景需要在CPI里開發一個集成流 - integration flow(下文簡寫為iFlow), 用于定義當其收到消費者傳入的product ID后,應該進行何種處理。
和ABAP里的程序需要存儲在一個開發包里一樣,iFlow也需要存儲在一個包里,稱為Content package.
進入CPI后在此處創建一個Content package:
然后點擊上圖的Artifacts進入iFlow創建界面:
取名Jerry first integration flow, 再點擊就能進入iFlow的圖形化編輯界面了。
一個新的iFlow創建之后的默認界面如下:
點擊上圖最左邊的Sender圖標,將其拖拽到上圖中間integration process矩形框內的Start圖標內,這個動作會幫助我們創建一個inbound adapter,類型我們選擇HTTPS,意思是這個iFlow期望其被消費的方式是HTTPS.
在Adapter的Address里維護一個url片段/CloudIntegrationTrials, 等到最后該iFlow正式部署后,生成的endpoint就是以該片段結尾,屆時我們可以在postman等工具里使用該endpoint消費這個iFlow.
考慮到現在流行的Restful API實現都期望其消費者以JSON格式傳輸請求內容,我們也沿用這個最佳實踐,因此首先拖拽一個JSON to XML Converter到iFlow integration process建模區域的矩形框里,將JSON
格式的用戶輸入轉換成XML格式:
然后再使用Content Modifier,將XML格式里的product ID的值提取出來。
下圖展示了Content Modifier通過XPath將XML格式的輸入里的productIdentifier這個字段的值提取出來。
有了product ID,可以進行OData調用了。從iFlow建模的工具箱里拖拽一個External Call出來:
類型選擇成OData V2:
指定前面提過的OData服務的url:
選擇該OData服務的Products節點作為消費的對象:
將OData Product節點的ProductId字段綁定到前一步驟通過Content Modifier解析出來的包含了用戶輸入的productIdentifier字段。
就像小朋友們搭積木一樣,我們把iFlow工具箱里提供的元素,通過拖拽的方式組合成了一個圖形化的流程。點擊Deploy進行部署:
部署成功之后,抄下這個生成的endpoint:
在Postman里向這個endpoint發送一個GET請求:
部署在SAP Cloud Platform上的CPI iFlow接收到了請求后,就會按照我們維護好的邏輯,解析出Product ID,調用OData服務,將該ID對應的Product明細數據作為結果返回給消費端。
和SAP CRM中間件有各種通過事務碼比如SMW01訪問的監控應用一樣,SAP CPI也有類似的監控程序:
希望這個最簡單的例子能讓還沒有接觸過SAP CPI的朋友對其作用有個最直觀的了解,感謝閱讀。
要獲取更多Jerry的原創文章,請關注公眾號"汪子熙":
總結
以上是生活随笔為你收集整理的给用过SAP CRM中间件的老哥老姐们讲讲SAP CPI的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 平安车抵贷申请条件
- 下一篇: 如何在SAP Cloud Platfor