摘要:關于的跨域問題的討論網(wǎng)上有太多的資源了。直入主題,最近我正在做一個原型開發(fā)通過云平臺和把系統(tǒng)上的暴露出來,給微信消費。請求得到響應之后,再將其發(fā)送給。回到我的原型開發(fā)需求,云平臺上的消費如今通過來實現(xiàn),為簡單起見,我將硬編碼在里。
關于JavaScript的跨域問題(Cross Domain)的討論, 網(wǎng)上有太多的資源了。國內的程序猿寫了非常多的優(yōu)秀文章,Jerry這里就不再重復了。
直入主題,最近我正在做一個原型開發(fā):通過SAP云平臺和SAP Cloud Connector把On-Premise系統(tǒng)上的ABAP function module STFC_CONNECTION 暴露出來,給微信消費。
這個function module的邏輯很簡單,直接把輸入?yún)?shù)REQUTEXT的內容不加任何處理,拷貝到輸出參數(shù)ECHOTEXT。
具體操作步驟參考我的公眾號文章:使用Java+SAP云平臺+SAP Cloud Connector調用ABAP On-Premise系統(tǒng)里的函數(shù)
部署到SAP云平臺后,通過如下的API endpoint進行調用:
https://demoi042416trial.hana...
然后在我的微信消息服務器上發(fā)起如下的AJAX調用去消費(因為是POC,所以把API endpoint硬編碼在第3行):
遇到了意料之中的跨域錯誤:?No "Access-Control-Allow-Origin" header is present on the requested resource.
如何解決?
解法1:Cross-Origin Resource Sharing
如果服務器端的響應能夠通過編程或配置去影響,那么可以借助Cross-Origin Resource Sharing,在HTTP響應結構中添加字段Access-Control-Allow-Origin,其內容根據(jù)實際業(yè)務賦以需要的origin字段即可。這里的origin在Jerry看來就是一個白名單。
解決方案參考我的博客:
Cross domain request in ABAP and Java
https://blogs.sap.com/2017/05...
解法2:JSONP
用JSONP也能解決跨域問題,但這個方法同樣需要在服務器端通過編程方式做一些處理。具體使用方式參考我的博客:
Play around with JSONP in nodeJS server and ABAP server
https://blogs.sap.com/2017/06...
而我使用SAP云平臺加上Cloud Connector將On Premise上的function module暴露到公網(wǎng),這種方式開發(fā)人員無法對HTTP的響應頭進行編程或配置。因此JSONP對于我原型開發(fā)解決跨域問題也沒有幫助。
在SAP云平臺的Mobile Service for Development and Operations cockpit里有對應的Cross Domain Access參數(shù)配置。不過我的原型開發(fā)沒有用到SAP云平臺Mobile Service這套架構,因此也不適用。
解法3:自開發(fā)ProxyServlet
接下來咋辦?Jerry以前做CRM Fiori開發(fā)時,用的是Eclipse IDE,在本地起一個Tomcat,上面跑的Fiori應用也能通過localhost這個域訪問到On-Premise系統(tǒng)域上的OData服務。當時咋不會遇到跨域問題呢?仔細回憶了一下,當時我們的Tomcat服務器上還部署了一個Proxy Servlet。Index.html發(fā)送的AJAX請求被ProxyServlet攔截,由ProxyServlet通過Java代碼向On-Premise系統(tǒng)發(fā)起請求。請求得到響應之后,ProxyServlet再將其發(fā)送給Index.html。
這種類型的Servlet其原理在我的這篇博客里有詳細介紹:
Explore the com.sap.ui5.resource.ResourceServlet
https://blogs.sap.com/2014/12...
思路清楚后,寫代碼實現(xiàn)就很容易了。上圖對應的Java Web項目的源代碼在我的github上:
https://github.com/i042416/SC...
1. index.html里發(fā)送的AJAX請求實際指向的處理者是ProxyServlet:注意下圖第三行的請求url路徑中的proxy。
2. 開發(fā)一個ProxyServlet,攔截url路徑里包含proxy的那些請求。回到我的原型開發(fā)需求,SAP云平臺上的API消費如今通過ProxyServlet來實現(xiàn),為簡單起見,我將API endpoint硬編碼在ProxyServlet里。
經(jīng)過測試,能按照期望的方式工作:域localhost的AJAX請求能夠成功訪問SAP云平臺上的API:
寫完之后我在Google上搜了一下,發(fā)現(xiàn)SAP已經(jīng)在github上發(fā)布了一個標準的Proxy project,用于處理這種JavaScript跨域訪問的問題,大家有興趣可以了解一下:
https://github.com/SAP/cloud-...
更多閱讀
使用Java + SAP云平臺 + SAP Cloud Connector調用ABAP On-Premise系統(tǒng)里的函數(shù)
使用JDBC操作SAP云平臺上的HANA數(shù)據(jù)庫
使用Java程序消費SAP Leonardo的機器學習API
C4C和微信集成系列教程
要獲取更多Jerry的原創(chuàng)技術文章,請關注公眾號"汪子熙".
文章版權歸作者所有,未經(jīng)允許請勿轉載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/69545.html
摘要:關于的跨域問題的討論網(wǎng)上有太多的資源了。直入主題,最近我正在做一個原型開發(fā)通過云平臺和把系統(tǒng)上的暴露出來,給微信消費。請求得到響應之后,再將其發(fā)送給。回到我的原型開發(fā)需求,云平臺上的消費如今通過來實現(xiàn),為簡單起見,我將硬編碼在里。 關于JavaScript的跨域問題(Cross Domain)的討論, 網(wǎng)上有太多的資源了。國內的程序猿寫了非常多的優(yōu)秀文章,Jerry這里就不再重復了。 ...
摘要:小的時候,聽過牛頓這樣謙虛的一句話如果說我看得比別人更遠些,那是因為我站在巨人的肩膀上。。發(fā)布一個的事件,事件包含創(chuàng)建訂單的字段。 這周Jerry在SAP上海研究院參加了一個為期4天的Kubernetes培訓,度過了忙碌而又充實的4天。Jason,Benny和Peng三位大神的培訓干貨滿滿,借此機會,Jerry和過去的兩位老領導Patrick和Evan敘了敘舊,也拜見了上海SAP圈子里...
摘要:小的時候,聽過牛頓這樣謙虛的一句話如果說我看得比別人更遠些,那是因為我站在巨人的肩膀上。。發(fā)布一個的事件,事件包含創(chuàng)建訂單的字段。 這周Jerry在SAP上海研究院參加了一個為期4天的Kubernetes培訓,度過了忙碌而又充實的4天。Jason,Benny和Peng三位大神的培訓干貨滿滿,借此機會,Jerry和過去的兩位老領導Patrick和Evan敘了敘舊,也拜見了上海SAP圈子里...
摘要:小的時候,聽過牛頓這樣謙虛的一句話如果說我看得比別人更遠些,那是因為我站在巨人的肩膀上。。發(fā)布一個的事件,事件包含創(chuàng)建訂單的字段。 這周Jerry在SAP上海研究院參加了一個為期4天的Kubernetes培訓,度過了忙碌而又充實的4天。Jason,Benny和Peng三位大神的培訓干貨滿滿,借此機會,Jerry和過去的兩位老領導Patrick和Evan敘了敘舊,也拜見了上海SAP圈子里...
摘要:我通過這篇文章把今天工作中遇到的跨域和請求的一個坑記錄下來。預檢請求機制的使用,是為了避免跨域請求對服務器的用戶數(shù)據(jù)產生未預期的影響。我使用了認證方式,這種方式不會造成該請求成為一個需要預檢的請求,所以最后跨域成功了。 我通過這篇文章把今天工作中遇到的HTTP跨域和OPTION請求的一個坑記錄下來。 場景是我需要在部署在域名a的Web應用里用JavaScript去消費一個部署在域名b的...
閱讀 908·2021-09-03 10:42
閱讀 1518·2019-08-30 15:56
閱讀 1453·2019-08-29 17:27
閱讀 879·2019-08-29 15:25
閱讀 3166·2019-08-26 18:27
閱讀 2487·2019-08-26 13:41
閱讀 1895·2019-08-26 10:39
閱讀 1585·2019-08-23 18:36