Java Based Apps on SAP Cloud_5_其
2017-05-08 本文已影响0人
LiuliuZhang
API管理
HCP中,启用API管理服务,通过访问API门户的链接,进入API管理界面
data:image/s3,"s3://crabby-images/8eb0b/8eb0bf2ea61da2421bd4fd9cf12c3afde0593fd9" alt=""
在Webshop应用中,我们请求产品列表的URL如下
data:image/s3,"s3://crabby-images/e85f7/e85f7dfcccf9971ff77ad1ee2964d7a65c6b55a4" alt=""
点击Quick Action中的API,可以打开创建API页面,URL为https://espmc5228335trial.hanatrial.ondemand.com/espm-cloud-web/espm.svc/,API Base Path我们可以填/v1/os/espm/ (注意在本应用中,最后以'/'标记结尾)
data:image/s3,"s3://crabby-images/a9ee0/a9ee0a2e69cbcf497e93f2790d7f0d1c8fe14890" alt=""
我们得到创建的URL https://c5228335trial-trial.apim1.hanatrial.ondemand.com:443/c5228335trial/v1/os/espm/
访问该url可以得到产品的信息
点击Policies,点击Edit,选择PreFlow,增加Verify API Key,下面代码中改成
<APIKey ref='request.header.APIKey'/>
,更新并保存data:image/s3,"s3://crabby-images/8c81d/8c81d407beda655acae2766e0e7a819b6ea3c49b" alt=""
再访问API URL,会得到错误信息
Failed to resolve API Key variable request.header.APIKey
。在API Portal页面通过Quick Action的Product链接创建Product,并选择前面创建的API
data:image/s3,"s3://crabby-images/65c42/65c42b791320c62cacc6eccead54780863ae61a4" alt=""
点击HCP API管理中的访问开发人员门户,可以看到前面创建的Product,首次登陆需点击Regist注册为开发人员
data:image/s3,"s3://crabby-images/b66d7/b66d7476134f9650cb1b78004e1d1c940a37b3df" alt=""
进入后,点击Subscribe->New Application,创建ESPM-UI
data:image/s3,"s3://crabby-images/7f947/7f947b7f54c156e837b2793ca65a3feb9703f289" alt=""
在Consume下,可以得到Application Key与Application Secret
data:image/s3,"s3://crabby-images/ea8f0/ea8f0976918cd88faf8091c42a8c87b5d2da6e72" alt=""
点击Test,添加Hearder参数,再访问即可访问到Product的信息。
data:image/s3,"s3://crabby-images/7217c/7217c7229c9af7fb5600d8dc04b13debbe10a349" alt=""
更新APP为API Management Branch,点击设置按钮修改为API Management Call
data:image/s3,"s3://crabby-images/f14b0/f14b02d8e70860d25396852861944a8c2843c7e4" alt=""
此时会有
Origin 'https://espmc5228335trial.hanatrial.ondemand.com' is therefore not allowed access.
的错误修改API的Rote Rules如下:
data:image/s3,"s3://crabby-images/7e2c3/7e2c364c8559c05a8fe5f9a167881877ecc900cf" alt=""
在PostFlow中,添加Assign Message
data:image/s3,"s3://crabby-images/c6a95/c6a958613452fd8974eca317d427ec13cb7155c5" alt=""
代码如下
<AssignMessage async="false" continueOnError="false" enabled="true" xmlns='http://www.sap.com/apimgmt'>
<Add>
<Headers>
<Header name="Access-Control-Allow-Origin">*</Header>
<Header name="Access-Control-Allow-Headers">set-cookie, origin, accept, maxdataserviceversion, x-csrf-token, apikey, dataserviceversion, accept-language, x-http-method,content-type,XRequested-Wit</Header>
<Header name="Access-Control-Max-Age">3628800</Header>
<Header name="Access-Control-Allow-Methods">GET, PUT, POST, DELETE</Header>
<Header name="Access-Control-Expose-Headers">set-cookie, xcsrf-token, x-http-method</Header>
</Headers>
</Add>
<IgnoreUnresolvedVariables>false</IgnoreUnresolvedVariables>
<AssignTo createNew="false" type="response">response</AssignTo>
</AssignMessage>
在PreFlow中,CheckAPI添加Condition String:request.verb != "OPTIONS"
刷新后,可以访问
data:image/s3,"s3://crabby-images/045dd/045dd795093ba592a71f053efc1a0650fc819554" alt=""
Translation HUB
启用HCP的SAP Translation HUB服务
添加File Upload项目
data:image/s3,"s3://crabby-images/9bf1e/9bf1edaf54aaca854ff7a6d461f298c48ad986ec" alt=""
上传i18n.properties文件,上传成功后,在Translation标签下可以自动翻译,修改翻译的内容
data:image/s3,"s3://crabby-images/a673a/a673ae7df82f2f87501098e7c1bf3c3a6583c3ad" alt=""
修改后,点击下载翻译文件,粘贴到i18n文件夹下,更新APP,即可通过url加后缀sap-language=de等内容查看相应语言下的页面。
Mobile Scenario
GitHub上下载HTML5-Retailer和HTML5-Workshop Branch
data:image/s3,"s3://crabby-images/ff0eb/ff0ebd62449dda54cf361b5d9f3e5e0d9e96a1b4" alt=""
在HCP的连接中,导入两个项目的Destination,更新其中的url
data:image/s3,"s3://crabby-images/3d629/3d6299708e16ad6768dc46940306a828718e9ee8" alt=""
打开WEB-IDE,File->git->clone repository,clone github上的url
data:image/s3,"s3://crabby-images/cf07b/cf07b57d736b7b30966b55e70308a14caedca328" alt=""
创建Local Branch,点击加号,选择Html5-workshop
data:image/s3,"s3://crabby-images/1dd12/1dd12c8aa763fdad0a870553940285030a2fef0b" alt=""
同样的方法创建Html5-retailer Local Branch。
HCP中启用Portal服务,创建新的站点,模板选择SAP Fiori Launchpad。
在站点目录中,将其发布并设为默认。
data:image/s3,"s3://crabby-images/72339/72339d35fa0f78a5e623f868299c7274da8c55db" alt=""
在WEB-IDE中,将项目Deploy到SAP HANA Cloud Platform,Application Name为workshop,并将其注册到Fiori Launchpad
data:image/s3,"s3://crabby-images/dbd2c/dbd2c15a14c1ec6ba0db18ed0e64f96859ee35fd" alt=""
Application Name为com.sap.espm.webshop,站点选择前面新建的ESPM,Retailer同样的步骤
部署完成后,可以查看
data:image/s3,"s3://crabby-images/b78dc/b78dce1097b81c53869c54ea000fb9de04c6f0be" alt=""
在HCP中新建webshop与retailer的租用
data:image/s3,"s3://crabby-images/5610c/5610c7735b937c967f1f83b150bb5619b719c655" alt=""
启用HCP的Mobile Fiori服务